this post was submitted on 27 Jun 2025
        
      
      822 points (94.9% liked)
      Programmer Humor
    27030 readers
  
      
      479 users here now
      Welcome to Programmer Humor!
This is a place where you can post jokes, memes, humor, etc. related to programming!
For sharing awful code theres also Programming Horror.
Rules
- Keep content in english
- No advertisements
- Posts must be related to programming or programmer topics
        founded 2 years ago
      
      MODERATORS
      
    you are viewing a single comment's thread
view the rest of the comments
    view the rest of the comments
 
          
          
But seriously, what IS vibe coding?
It's just prompt engineering for coding. Let an AI dump a bunch of code for you, debug until it no longer errors, pull request and repeat next sprint.
5% of the time, it works every time
Brought to you by (us) security researchers who will happily come in and sort out your security issues later. For a very hefty hourly fee.
I really doubt anybody will be happy about it, even after considering the size of the fees. And also, you have a very high estimation of the capacity of those people to notice they have to call you, I really doubt it's deserved.
Deserved. These companies need to find it out the hard way.
So I can do programming and find and fix bugs.
How do I go on to advertise myself to them as a security researcher and get that hefty hourly fees?
Problem is, I am not very good at ~~fooling people~~ marketing.
The critical detail being that you don't actually know what's inside (and it's definitely bad). Just using LLM assistance for a your boilerplate code doesn't count.
Is it truly a deviation from outsourcing code to a 3rd party?
Yeah, because at least a decent 3rd party might hand you documentation and have the sense to build something consistent or maintainable. AI has a limited context scope and frequently suffers a type of short term memory loss that results in repeated work or variations in work that confuse the end result.
Yeah, unlike an outsourcing outfit an AI company won't take the fall when given shit requirement and shit pay they deliver shit work.
These days it more or less explicitly refers to asking an LLM to write your code for you based on prompts.
But on a broader spectrum it is just the idea of (I forget the buzz word) Ticket Driven Development. A manager defines software based on a series of (jira, gitlab, kanban, whatever) tickets/issues and someone below them (in this case, an LLM) implements it.
Done properly? It is incredibly effective as it allows designers and "idea people" to work to their strengths and junior developers to work to theirs. The problem being that, much like when it is a junior dev under them, the person making the tickets likely has no idea what they are doing.
Which is the big problem. Someone who has been writing scripts for decades? Using chatgpt to get the syntax of a function or even to write a utility script is great. They can focus their brainpower on the harder/more fun stuff. Someone who has been writing code for, at most, a year or two? They never learn those foundations and never have a way to do anything the LLM can't (or verify if the LLM is correct).
I’ve been programming for over half my life now, I actually like vibe coding with Claude these days.
It basically gets me through the hump of “ugh this task is going to be annoying as fuck to do” which is where I personally lose most of my efficiency (I have a lot of difficulty forcing myself to do something I don’t want to).
It’s like when I had interns and I’d give them tasks. Describe the work, scope it, add some guard rails to keep it directionally okay, and send it off to get reviewed later. And that works great with modern agents.
I will say vibe coding is damn good at debugging, way better than I am, so I use it for that a lot now.
I've been a Jr coming up to two years. When working on tasks I have a rough idea of what I want to achieve and some steps on the way there, but don't know how to actually implement it. I've found using copilot useful to fill in some of the gaps and give me ideas and direction.
I'm concerned that there are skills I am missing out on developing, but at the same time if AI is being pushed so heavily is it not something I should lean into to be better equipped in working with it?
I used to have a program that would search docs and I'd read stack overflow all the time. Back then it was RTFM or GTFO, so stack overflow meant I wasn't learning right.
I think you'll be fine. Sometimes it's good to read docs, sometimes it's good to just see how things work in practice and up to AI that last part was hard to come by.
That is literally what the job is. If you can't do that then you aren't an engineer.
I'll tell you what I told my nephew: Yes, everyone is going to use AI to one degree or another. So why would I hire you over anyone else? Or, more pointedly, why would I hire someone at all?
Getting to that interview gets harder and harder every year (every month, really). But engineers (and even many managers) can immediately tell someone who knows their shit versus someone who "vibe codes" all the "hard parts".
AI doesn't get everything right, and you need someone capable of validating that and pivoting it in the right direction. But also AI cannot currently do everything, so you need someone to fill those areas. Where I work there is a push to engage with AI more, probably to train it.
This is like any other job really, people aren't hired based purely on their skillset, but other factors too such as their capability to learn, their personality, will they mesh well with the existing team, have they got drive to make things better, do they have soft skills to position themselves to become better, is the person adaptable - are they able to use new technology to their advantage or are they stubborn and stuck in their old ways?
I want to be in a position to know and understand all the fundamentals, but is the bar for what is considered fundamental shifting? Once upon a time those who were writing low level code would have said what they do are the fundamentals, but as time went on we got new levels of coding and so knowing how to write low level code is no longer a required skill.
Apologies if I've misunderstood what you're trying to say. But thanks for responding, these kinds of discussions are helpful.
And who is going to be able to fill those gaps? Probably not the person who "knows what I want to achieve but (...) don't know how to actually implement it".
Which ties in to
If the bar is "I know how to ask a magic box to do my job for me" then there is genuinely no need for previous training and experience and a company won't be hiring engineers or spreadsheet gandalfs or marketing experts. They'll hire the cheapest "prompt engineer" they can, underpay them, and then replace them the moment they ask for a cost of living increase.
And... the companies considering that really aren't the ones with any longevity. Yes, yes, any port in a storm. But they will RAPIDLY run into that wall and have no way to move past it. Whether that is getting the senior engineer in cargo shorts to do it or curating training data to improve the model.
And that is another barrier that MANY companies have run into.
The average coder? Yeah, they don't need to understand how to optimize a loop. But when there are forty tools on the market that all just call pytorch? The one company that knows how to optimize a critical path function suddenly looks REALLY good with their 10% performance (and thus power) savings.
Again, these tools are incredibly powerful and I regularly use chatgpt et al to generate a first draft of a utility script. And I've been using editor plugins for... sweet Eothas over two decades now, to generate docstring stubs and even a lot of unit tests. And people SHOULD know how and when to use these tools.
But you also have to consider what you can get out of it. "AI" generated documentation is pretty much worthless outside of checking off a box that you have documented every function in the code. Your LLM won't understand what that function was trying to achieve or why "it is wrong but that is because this library is wrong" and so forth. Any documentation that is actually meant to be referenced still needs a proper pass from whoever drew the short straw in Engineering.
Same with testing. AI can generate tautologies. AI won't stress test your code because it doesn't know what you think that code might do in the future. By all means, generate the boilerplate, but you are still going to be the one who has to go in and add that really weird corner case that TOTALLY didn't break prod lats month.
And... you know who historically did those tasks? Interns and junior engineers. The same ones who are adamant that their entire job can be done by chatgpt and lamenting that they don't know how to move from idea to implementation. And guess how you learn how to do that?
Thanks, it's interesting to read your thoughts on this.
If you were a Jr entering the job market now, and have management encouraging vibe coding because they want quick results, how would you go about getting the experience and building the right skillset?
There are two layers to that.
The first is how to develop skills. And you do that the exact same way everyone before you did it: you actually do the work. Calculators are awesome but you still learn how to do long division and the like because it gives you insight into how to approximate things. Same with sims/solvers versus actually solving PDEs.
The other is... if your boss wants you to feed everything into an LLM then you won't have a job much longer. So you can either look for a new one or work toward more advanced tickets/tasks. Make it clear that LLMs have limitations and that some stuff will need a proper coder and that YOU are that proper coder.
Ten years and counting here, fuck if anyone knows at this point. My personal (maybe a bit cynical) take is that it really doesn't matter as the amount of coding skill you use maxes out in the first few years of your career (for 90% of us anyhow), after that cat herding skills and pragmatic system architecture is what's important. It becomes more important to know what not to do rather than the opposite.
So it doesn't really matter how fast you are at leetcode if you can navigate the particular brand of spaghetti your workplace is cooking, plus points if you are able and willing to grok new kinds so you can hop jobs because raises are so last century.
It's feels before reals, but applied to coding.
Using chatgpt and not checking its inevitably incorrect output and sending it
Vibe coding is when an AI writes the code for you.
It's magic