I long ago stopped getting caught up in “that discussion” about recent trends despite a stream of people lobbing leading questions to get the ball rolling. Because I also try to not do so more rudely than necessary, I have developed several diplomatically worded (or at least ambiguous enough to float opaquely off to the side of the offense spectrum) ways of essentially saying the following: The simplest and cheapest way of [A] learning the “computer science” end of software is by becoming proficient in Lisp, [B] learning the “engineering” end of software by becoming proficient in Forth, [C] learning how “busywork” is a dangerous and demoralising thing to confuse with “actual work” by maintaining some Java code, [D] learning how insidious and self-sabotaging “expert beginner syndrome” is by reading a lot of the relevent code-reviews and blogposts when maintaining Javascript & Python projects, [E] learning how mob-mentality and populism can lead to selective blindness and architectural stubbornness by working with large volumes of C & C++ code, [F] learning how it is all really abstraction-layers over something akin to an old-shool phone switchboard by working with Assembler, [G] learning how the only work with longevity is that which stands on the shoulders of giants by using Fortran libraries, [H] learning how the mere act of developing using languages with baked-in discipline can be inherently educational by using DbC/TDD/BDD/dependent-type/formally-verifying/etc based languages (SPARK-Ada, Haskell, Eiffel, ACL2, Rust, etc), and then [I] learning how - after a certain level of experience - the languages, frameworks, and tools become less important than the engineers’s mindset and the work that happens both before and after the fingers hit the keyboard…by finding semi-performant techniques for implementing masochistic things like a VM and a network stack in Bash script (as hobby tasks, not for real use). If they are coming from a more hands-on/hardware background I also recommend [J] how eye-opening it is to maintain your own customized LibreCMC image flashed onto an open router (the older/smaller the HW the better, because you have to be increasingly creative with your kernel & OS configs), and [K] how educational it is getting a RISC-V working on an FPGA. I top it off by saying that [L] despite coding on-and-off since my start with z80 assembler on an Amstrad in the mid-80s I still feel like a beginner with so much to learn, and [M] that fact is by far the part I love most about the field (not just field of “work” but of “mental endeavour”) - far more than status/seniority/raises. I find I don’t get bombarded so much with JS-framework-du-jour zealotry and expert-beginnerism after that.
When they said that it wouldn’t be a “get off my lawn” post, I was like “oh no, it’s 100% going to be that”, but then I read, sympathised and… I’d actually offer to get the people in the examples off the author’s lawn on their behalf, because they were just so disappointing.
Though, to be fair, this was pretty much a problem in the superficiality of the frontend development circle that maybe was taught just that from the beginning, so they conflate notions of computer science with the language they use most, because there was no formality in their approach to learning, which is sort of a good thing IMO, because it’s way more effective at making you productive fast and knowing where to put your hands. Just that, after that, one shouldn’t pretend to have the understanding necessary to pronounce on topics they actually haven’t dug into, they, as I, and anyone for that matter, should delve into them first to know what they’ll be talking about.
What the author identifies as “developer disconnect” I think is ultimately a product of the popularisation of coding beyond the academic setting, when you learn on your own, you can have several holes at the base of your knowledge, holes that would be glaring to someone that took a more standard path to learning, but that weren’t limiting enough to impede their advancement and that is hardly ever addressable, because still, when you’re on your own, you have the (blessed) choice to skip everything you don’t care about, until you need it at least, if you ever doOne can argue that any programming is computer science,
One could argue that, but I think it would be a weak argument.
Keeping within the subcategory of software, I think of computer science as the theoretical side and programming as the practical side. The same distinction is sometimes made in other fields, like physics.
Seems to me that the author saw a show written by people with a narrow and shallow understanding of the field. For better or for worse, it happens on TV all the time. If he wants to demonstrate a widespread disconnect in the software community, there are probably better examples out there.
Yeah, computer science is the more about theoretical side of computation and the analysis of algorithms. For example, proving that a certain algorithm is a solution to a problem and has a particular time complexity. That’s more mathematics than practical programming.
(disclaimer: I haven’t read the article, I’m just replying to you because your comment was interesting)
I think your theoretical vs practical framing is useful, but as a (non-computer-)scientist, I find it fascinating to consider how a biomedical scientist uses programming compared to someone whose background is much more grounded on the compsci/IT/programming side.[1]
[1]: I sometimes joke that, compared to many of my scientist colleagues, I am an exceptional programmer, and this says a lot about the average quality of the code that scientists tend to write when they don’t have much dedicated training or experience in programming
1 ↩︎
Scientists write code that works for them, so that’s fine if the code isn’t optimized.
When your software is your product, then it needs to be much more optimized.
It’s not fine if the code needs to be used by other scientists though, which it often will be, even within the same research group. I have a friend who worked in a lab where one of their PhD students wrote a bunch of helpful code that was an unmaintainable mess that ended up breaking a lot of work flows at some point a year or so after the creator of it had left. It was kludge upon kludge upon kludge, and the thing that finally broke seemed to be dependency related, but I couldn’t figure out what the hell was going on with it (I was asked to take a look).
There’s a lot of duplicated effort in science. Scientists tend not to think about stuff like software ecosystems unless they’re in a subfield that has been doing computational stuff for a long while, like bioinformatics. When it comes to code, there’s a lot of inventing the wheel from scratch and that leads to weird square wheels that work good enough to then have more code built on top of them. Software might not be scientists’ product in the same way as it is for IT people, but it often ends up being a part of the wider product of methodological reproducibility
Writing maintainable code is an art form. Like most art forms it can mostly only be learned by practice. So if you don’t have much experience maintaining long lived systems, it’s difficult to know what works and what doesn’t. Most universities don’t teach this as well, so it’s mostly something people learn in the industry.
Then I believe there’s also some aspect of pride in writing overly complicated code. It’s the belief that ”other people can’t comprehend my code because they’re not as smart as me”, when it’s actually ”I suck at writing comprehensible code”.
Yeah, that tracks.
At work someone estimated adding a section of static content to a page that uses React as 3 story points.
They were searching for components that would style the header and paragraph elements just as they wanted them, but were coming up short.
Instead I simply added it with html elements and a couple of lines of CSS.
5 minutes. Done.
😐
I thought ambagious was a typo of ambiguous. New word day!
Holding their hand through one page in vanilla JS is a great investment in your junior dev if this is an issue
I swear this isn’t a get off my lawn post
Proceeds to spend 5 paragraphs complaining about what people call the original Javascript. He has some valid points, but this is very much an older developer complaining about the new generation of devs.
I dunno some of these feel like fundamentals that any web dev should know.
You’re gonna have headaches down the road if you don’t know hiw static html works.
I heard of some people having trouble getting their head around React. I didn’t, and I thought it was because I had a pretty good foundation in functional programming. React’s magic is transparent if you understand things like first order functions and immutable data.
Now I wonder if the disconnect was even more fundamental.
new generation of devs
The new generation of devs sadly has a lot of people that only can type what they want to achieve into ChatGPT and blindly copy whatever code snippet it comes up with. But they can’t develop. Nor do they understand code written by others. They’re the reason things like NodeJS’s is-even package exists.
Published 8 years ago
I didn’t know that the new generation of developers were that far along in their careers already.
We’ve been saying that about new devs since there became a second generation of devs
Except when I was a new dev, it was blindly copying stuff from stack overflow
In Phaedrus, Socrates talks about the invention of writing:
“it will introduce forgetfulness into the soul of those who learn it: they will not practice using their memory because they will put their trust in writing, which is external and depends on signs that belong to others, instead of trying to remember from the inside, completely on their own. You have not discovered a potion for remembering, but for reminding; you provide your students with the appearance of wisdom, not with its reality. Your invention will enable them to hear many things without being properly taught, and they will imagine that they have come to know much while for the most part they will know nothing. And they will be difficult to get along with, since they will merely appear to be wise instead of really being so.”
This isn’t the new generation of devs. This is just new devs. Some people refuse to grow out of this stage.
New devs generally suck, I sucked a lot.
The problem I fear today is that there are more crutches new devs can rely on, until they can’t.
And it’s not a sharp boundary between getting by and not being able to work it
More crutches is definitely a problem. Personally, after vocally refusing to use chatgpt for months, my boss has now sat me down and told me to use it because it “halves his development time”.
My colleague and boss use it constantly. Guess whose job has become mostly debugging their code when they can’t get it to work and don’t know why?
That is very frustrating !
The main issue is that not a lot of companies want and do take the time to train less experienced devs. Every company is expecting new hires to be trained already.
So many new devs need to scrape by with whatever means they have. And it is true is a lot of industries.
College computer programming programs normally do not train people to immediately work, unless the students spend thousands of hours coding on their own. Most comp sci students avoid this.
So, when a new dev graduates and they did not do that extra work, then the first year of paid work is them putting in those hours while being paid rather than doing it for free
I am not in the US, so I cannot compare, but people here that go to college equivalent explicitly learn to code.
When people go into computer science at University, they are decent coders and can do a lot of things out of school.
People learn to pass tests, and do computer labs. They have hands on experience in several computer languages. But that is a far cry from what is really needed.
Probably most schools give the fundamentals regardless of country.
Can’t tell who has talent until they try to work a lot; often the people who do not code on their own are not very good, period
I think a student should at least do a few hours average work each week on their own projects , regardless of tech stack. It really shows after 4 years.
it’s like night and day between those that do this as a hobby and go to school ; verses the people who pass tests and do group projects in the labs but don’t do anything outside of what is required.
I’ve heard of the term “expert beginners”.
This is a generalization that has some merit. but ultimately, generalizing an entire group of people and making assumptions about them isn’t a good way to judge an individuals ability to code.
See what they can do, and then judge.
You must have missed the part where I said a lot of people, not all of them. There are people calling themselves “developer” that shine during the hiring process, but then can’t implement a random feature if there’s no ready-to-use library for it.
However, this doesn’t mean that there still aren’t lots of actual developers around, that know what they’re doing and can actually code in an actual programming language.
If you want to play true Scotsman, the embedded devs like to make fun of the web devs for being scared of bitfields and refusing to do logic with anything other than string matching and manipulation.
. . .
Secretly it’s partially because we’re absolutely terrified of strings in any form and simply refuse to use them.
There are a lot of sub disciplines to the field, some benefit a lot from GPT or blindly copying from SA, some don’t, but that’s ok either way. Keep your skill sets broad and you’ll survive.