Have you ever worked at a job where a guy who learned to program 20 years ago has to sign off on everything you do? I did, and it was awful. I've also worked at a place that hired nothing but fresh graduates, and that... actually turned out pretty well. There were cases where they wrote more code when they needed to, or used an unsafe construct when there was a better alternative... but they were willing to reason about things, to experiment, rather than just "this is how we do it". I'll take an untrained grad over someone who rigidly follows procedures any day.
It’s really incredible how common those people are, and how they’ve managed to eke out a living. The thing that has surprised me most is that there is no predictability to how a candidate will perform on a simple programming exercise, new grads are equally likely to pass as people with 15 years’ experience. (The failure modes are different though, new grads spend lots of time talking through every variable assignment etc; experienced people tend to throw every technique at the wall when they encounter an issue instead of slowing down and thinking through what they’re doing)
I've hired "zero experience programmers without a Bachelor". If there is a clear modicum of ability and desire, I'll give a person a chance to prove themselves.
At least for me, this has generally worked out brilliantly. A few of those hires turned into some of the most technically competent programmers I've ever worked with, and none turned out poorly. Some people are capable of educating themselves to a very high standard in a relatively short period of time. This is a primary characteristic of highly successful inexperienced programmers with degrees as well.
I guess I didn't explain my point well. I don't expect new grads to have "professional experience" (bad choice of words in my part), but a lot of companies expect them to have SOME sort of experience, be it an internship, open source stuff, personal projects, etc.
You'd be surprised how many people don't code outside of class and if you think that's fine and companies should train then I agree with you but it's not the reality most students are living in.
More than anything have learned that education and training are hugely important and hiring to train leads to mediocre staff who think their two years of development work stack up to your 4 years of college and 6 years of professional experience.
They take forever to start writing productive code, if they ever bother leaning at all.
I will never hire someone without a degree or equivalent experience again. Even for Jr. roles
My main hiring qualification has been "Will this person continue to write code that will make me get up in the middle of the night?" or "Will this person contribute to me only working 40 hours and having no emergencies?". I try not to hire the former and hire the later. The culture thing in the second paragraph is bull. A bunch of clones is no fun at all and doesn't give the proper vision.
That being said, the "Nothing a newb can do impresses me, because I can find a hole in it.” is a bit overblown. Learning means that you are going to get comments. Some good, some bad. This isn't grade school and I don't remember anyone handing out gold stars. This is the same crap attitude that leads directly to ageism since experience is not valued.
The article is a bit ironic. It apparently talks about people who don't learn and don't change but suggests to them to just go and "find a new profession"...
A new grad, compared to a 10 year veteran :D. Yes sure, it levels the playing field, totally. As if language and frameworks would mean anything. I don't even want to know what kind of "veterans" would compare to a new grad. If you are worth anything at what you are doing, you would kick any smaller team of new grads out of the park, even when working alone, in a language you don't know and with a framework you don't know. New grads essentially know nothing about software engineering, nada...
It's baffling to me how any company would think otherwise. Perhaps they should review their hiring policies then.
The concern I usually hear is not around the learning to program aspect. Instead, it's that fact that almost every other entry-level programmer is a college grad, and that hiring processes will be biased against older candidates.
I would much rather hire someone who doesn't know 90% of this stuff but has done professional software development for 2+ years, than someone fresh out of school who has memorized all this stuff.
The unstated counter-argument is that the employer will have to train inexperienced workers who will leave as soos as they become competent and experienced, or pay as much as you would for the experienced person in the first place.
Myself, I'd rather train someone up in my process without them learning bad habits, even if that means they're pairing with me for 30 hours out of 40. That said, I'm an exception.
Once upon a time, some companies hired new workers as QA, trained as QA, and those with the aptitude were moved into programming. I know that IBM still has an internship program that streams people into their system.
I'm in medical device software. I'm mid-way through my career (15+ years). I've been on my current codebase (which is 20+ years old) for 5 years. I work with a coworker who's been with this code base for 20 years, but is 45 years into his career. I push back hard when it's suggested that we bring on a fresh college grad (who wasn't even born when this codebase was initiated) and it's suggested to give him/her one of the harder tasks with no supervision. Management: "They have a degree in computer science, why wouldn't that be enough qualification?" Me:"For the same reason you don't name a recent MBA graduate CEO of our fortune 500 company".
Note: I'm all for hiring recent college grads, but they need to be paired with a senior dev, and management needs to understand that you're not speeding up the project this month. Ideally, you're investing in the robustness of your team. The challenge I face is that so many junior engineers are job hopping the first ~5 years. That's not a smear on them. It's good for them. But it's not great for me...
Meh, in pretty much every company I've seen there are lots of entry level jobs to be done. Sure, you can ask an experienced developer to take care of them, and they will, but they'd rather apply their skills to more challenging tasks, or you could give them to a beginner, let them figure it out and run it by a more experienced dev to review.
We've done that with a guy that had been out of programming for half a decade but wanted back in. Within half a year he was a great asset. I believe it's more about whether the person is happy to learn something new, not so much what they already know.
The hiring situation with no experience is a slightly different beast, particularly if you're not involved in open source or otherwise generating a lot of public code that people can look at.
People are rightly wary of hiring untested kids fresh out of college because so many of the just plain cannot program their way out of a paper bag. Not to accuse your friend of incompetence, it's just that until you have some kind of real portfolio, it's damn hard to sort the wheat from the chaff.
I wasn't saying that new grads are, on average, better than experienced hires. I was just saying that experience is not everything.
An experienced hire will outperform a new grad on a "build this project in 3 hours" test. But the new grad might actually be a fundamentally better engineer - they might be smarter, more careful, etc. Given 3 - 6 months of training, the new grad might actually make better technical decisions.
Obviously, the reverse can also happen: the experienced hire might be not only more knowledgable, but also smarter, more careful, etc.
The problem with the "build a project in 3 hours" test is that it weights experience and knowledge so heavily that you end up eliminating people who could be great, with a little bit of training.
Again, a new grad could also be a fundamentally terrible software engineer (there are fundamentally terrible software engineers with experience and with no experience). And in 20 years, they'll be a terrible software engineer with 20 years of knowledge and experience. They might be able to build a 3-hour project better than some smart inexperienced coder but I'd still rather hire the smart inexperienced coder (assuming I have some time to train them).
I would be sceptical of hiring somebody that has been code monkeying for 20 years, as in still making the same mistakes they were making 20 years ago. It's a smell of somebody that doesn't warn to learn new things, and has no commitment to quality in any sense of the word.
On the other hand, somebody that has deeply learned their craft and is still actively learning makes a very attractive employee. Age and number of years on the job by themselves say nothing about ability.
Part of the issue is that programming is largely seen today as a process of problem solving using an "agile" hack it 'till it works approach. Quick thinking to put out a fire or implement a quick feature using some new technology easily learned is most valued, along with the ability to be "flexible" when it comes to quality of work and workplace demands.
Given this, one might as well look to recruit some smart, cheap and enthusiastic graduate. Sadly industry experience and lessons learned don't seem so important.
I disagree with your statement but agree with your point.
I believe that's due to being curious and slightly introverted when young, so these people just have lots and lots of experience. Such people could be manufactured by training them on many different programming disciplines over many years. It's just that for almost any company, investing so much into training is not feasible. That employee might leave once training is over.
There's a huge difference in no work experience and no experience at all.
Hiring college grads without a lot of real world experience gives you the opportunity to mentor and train in good methodologies that I find older developers will refuse to implement without incessant fighting.
It is more work initially but the long run payoff has been fantastic in my experience. When you manage based on yearly expectations that are attainable life is so much more enjoyable.
The biggest key is management and upper management buy-in. Sadly that's exponentially more difficult to get when most places see IT as a sunk-cost instead of an opportunity to deliver more efficient workflows internally and externally.
I'm on the fence about working with developers that don't have college degrees. The gaps in their skill-set frequently causes issues no matter how much experience they've had.
reply