As a 40 something, you have a lot of strength and experience to leverage. Much of it might apply to programming.
For instance:
* People Skills - This is critical in almost every programming job, understanding what and why to do is more important is more important than how. Good communication is the path to that and many programmers get this wrong.
* Writing - Being able to take a ton of ideas and organize them into coherent, modular sections.
* Discipline - One thing that I have far more of at 35 than I did at 22. It is a critical component to learning as well as working through problems correctly (not half-assing it)
I agree. As a 50+ programmer/CTO I freely admit I'm nothing like as quick as I used to be at pure coding. I marvel at what some of the youngsters at work can do. I took a good long time out in management but even so, age catches up. YMMV.
But I'm way better at knowing what to do, and recognising how not to approach things.
My belief is that as you age, more and more of your brain is turned over from processing to pattern recognition.
If only my communication skills had advanced apace, so that I could convince others with less effort )
As someone approaching middle age, who has been coding professionally for a long time, I can tell you without a shred of doubt that I am a far stronger software developer than I was five years ago. I was far stronger then than I was ten years ago. The list could go on, but then you’d realize I’m really old :)
I completely concur. I've been programming since I was a teenager, practically grew up with computers, and I'm 50 now.
I'm still just as productive as I was in my 20's, but now I've got decades more experience than my peers and can see things that the hubris and arrogance of youth never let me see before - like, how important it is to be able to work with others, not hold onto projects selfishly .. how important it is to check oneself before one wrecks oneself, and so on.
If I had a way, there'd be so much advice I'd give to my younger self...
If anything I'm a much better programmer in my 40s than when I was younger. My cognitive capacity (being able juggle more balls at the same time) is about the same, probably a bit better now. My lateral thinking has definitely improved. And then of course I'm wiser because I have more experience and my instincts are just better.
What surprises me is I learn much faster now than I used to. But I guess it makes sense. I never stopped learning new things (coding or otherwise) so I've learned to learn. I also have more data points to compare new stuff to.
Interesting example to give. I always think it's good to have programmers with quite in-depth knowledge, and programmers who are more superficial in their programming knowledge but get stuff done.
In my experience, it's not so much about age, hence I'm not sure if that is relevant in there. (For example, I'm not sure if using VIM is something younger programmers tend to learn, and I'd guess more of the 'older generation' will know it).
41. I learned programming when I was 8 (basic on a C64) and I have as much fun programming today as I've ever had. Besides, there's no doubt I'm a better programmer today than I was 5 or 10 years ago and I keep learning new things.
Actually, I'm more worried about ageism than about the decline of my abilities. I work in academia, but I wonder if I could get a software engineer position if I wanted to.
I don't have any examples of code I wrote when I was in my early 20s, but definitely I'm sure I was quite naive. Especially if you consider development process, I had absolutely no idea what it took to build successful teams.
At around 30 I started to clue in and I can recall some designs which were actually not too bad in retrospect. Of course, a lot of the stuff that is taken for granted now (design patterns, TDD, etc) was not well known at that time and so I was exploring and learning things that few other people had experience with.
As another person posted, I'm also nearing 50. I would say that my code has improved a fair amount and I have learned a lot of other techniques which I didn't really know in my 30s (like FP). Rather than technique, though, I think the biggest thing I've learned is patience. I code very slowly compared to how I coded 20 years ago, but I think a lot more about every line. Kent Beck once said that when he wrote Smalltalk Best Practices that he started to evaluate every keystroke and to think why he was pressing that key. I find that I am doing that a lot now and it is very beneficial. The advice I give the young guys on the team the most is, "Stop typing so fast! You need to think about what you are typing" :-)
As I said, the biggest revelations for me are less about pure technique and more about how everything fits together. For example, my less experienced colleagues are often distraught over the perceived sins of the other people on the team. They worry endlessly about how to stop the "crappy programmers" (in their eyes) from "ruining" the code base. Nearly 50 year old me weighs the options and realizes that complaining/campaigning/scheming/negotiating/etc will take an order of magnitude more time than refactoring and will suck the fun out of the room. I like refactoring code and I hate arguing, and besides young people tend to be crap at cleaning (in general). So I clean things and eventually most of the others catch on -- not everybody, but it's enough.
I still get stressed out a lot and I'm hoping by the time I hit 60 I will have resolved those issues :-)
Most of the young people I work with are quicker witted than I am (I'm 50). However, I have an edge over most of them (IMHO). I have good work habits. I'm organised at work (though hopeless at home). I have good communication skills (strengthened by years of practice). I have compassion for my coworkers, having experienced the same things they are going through. I understand very well what my strengths are and I know how to lean on my comrades when I need to. Most importantly, when writing code, I have judgement based on experience (not blog posts), I don't freak out when someone changes my code, and I don't panic when we make mistakes. Finally I know how to hedge poor management decisions to limit downside without materially impacting productivity.
Also, I don't know about you, but I'm still learning important new things even at my age (and experience level). I don't see an end in sight, so either I'm a very slow learner, or there is more than 10 years worth of things to learn/experience.
I'm just over 50. Here's ultimately what I think about aging and programming:
Programming is fun. I enjoy it now, more than I ever have. Three times I've created software that has built a business and livelihood for others. That is super satisfying, and at the same time, usually the source of things that are not as fun as programming (taxes, accounting, lawyers, nasty people).
When I run across other programmers my age, I see a lot of unhappy people, and that is kind of sad. A lot of the unhappiness comes from one of three places:
* Not leaning new things and discovering that the isn't demand for what you did in the 90s and 00s. Career prospects are dim, and bitterness sets in. It's easily solved by picking up something new - but be careful, new doesn't mean things 15-20 years old. So many people jump out of one old tech into another one that is about to be old.
* A lack of interest in leading, and being hypercritical of leaders. Here's the deal: if you leading the team, you pick what you want to work on, and you pick how you build. If you are just on the team, you'll always be on the wrong side of decisions. It's easy to lead a small team, and experience is really the backbone of really, really great small "l" leadership.
* Pathological drive to be correct at all times. You know, they person that can't let the smallest mistake go un-punished, every bad decision second-guessed and being willing to die on the hill of correctness over the smallest mistake. This drive makes you good a programming, but it makes relationships with others terrible, and leads to being isolated, alone, passed over and unhappy. It's really hard, but learning to pick your battles and understand that battles can be won and jobs lost really goes a long way.
That said, there's an awful lot of aging, talented, experienced developers out there that are doing great things, and having fun doing it. Find a way to keep it fun.
> Do people lose interest in programming as they age?
No.
> Is it accurate to expect that older programmers are slower,
I do think a lot more about code before writing it. I don't just starting typing in random crap hoping to feel my way towards a solution. Quick reflexes and high WPM typing is not useful for programming.
> make more mistakes,
Far, far fewer. In fact, one gets pretty good at zooming in on where the bug is in other peoples' code. It's a pattern recognition thing.
> and would rather be doing something else such as managing programmers?
63 year-old career programmer here. I can attest that this list is pretty much a straight line to the place where I am at, with everything just dialed up a 20 year notch (hehe!)
I do want to add one more thing to the list:
* Find a well-managed team of really nice people that know more than you do.
Every part of this requirement is important, especially for generalists like me!
[for the record, I'm 58 & and an active software developer]
There are two points I'd like to add:
My brain isn't as elastic as a younger programmer's. My brother, a software developer close to my age, once said, "It's as if I used to have 20 registers, and now I'm down to 12". I can't keep as much in my head as once. My twenty-something co-worker, Belinda, once remarked, "It takes you a while to read code & understand what it's doing". She was right. Using solely that metric (elasticity), I'd have to say that the forty-year-old version of myself was faster than the fifty-eight-year-old version.
The other point I'd like to make is that there's a certain class of developer who has grown tired of developing & learning new skills, but doesn't want to retire. I remember my co-worker Larry would spend far too much time reminiscing about 640k computers and showing pictures of his grand kids. He didn't seem to want to work much. They let him go, and though I liked him personally, I think management made the right decision.
If even that were true! I really don't see my 40s and 50s being better than now. Personally, my biggest weakness is that I am passionate about the technology and getting my hands dirty. If I start getting practice in management, crafting bold powerpoints, dressing up, etc. I think I'd go far in tech in my later days. But I won't because I love getting my hands on code. sigh
Agreed. Of course, the ageism's definitely out there; if you're able to ignore it, good on you. What I can say, though, is that I've learned a hell of a lot more from older programmers than I ever have from younger ones.
> I'll still produce working code faster than them
I think my advantage (I'm over 40) is that I produce the _right_ working code. Listen to the client, think about the problem, suggest short cuts or alternatives (including COTS if needed). I am much more focused on solving problems now than I was when I was younger.
I’m 36 and I kind of consider myself an older programmer, if for no other reason than the fact that others my age also consider themselves older coders.
I’m not the greatest, but I get the job done and produce results. That’s what businesses want.still, I wonder how sustainable that is.
I've met older programmers that were exceptional (passionate programmers that keep up with the craft, eg. at least enough to be able to explain exactly why they dislike JavaScript but love Go and Python even if they use none of these languages in their "day job") and older programmers that were mediocre (these are usually the ones still using only the language they started with, programming specific types of apps in the niche industry they started in).
I don't think you can pigeonhole this demographic any more than any other, but there is at least one thing to keep in mind -- the exceptional "old farts" are really exceptional, because they have the same passion as any other passionate programmer, plus a boatload of experience. When you really want to ship something, no amount of youth-fueled semi-experienced 16 hour workdays makes up for a solid 8 hours from someone with decades of experience who still loves writing software.
Looking at myself, I think my biggest strength is in knowing what not to do.
reply