TE
TechEcho
Home24h TopNewestBestAskShowJobs
GitHubTwitter
Home

TechEcho

A tech news platform built with Next.js, providing global tech news and discussions.

GitHubTwitter

Home

HomeNewestBestAskShowJobs

Resources

HackerNews APIOriginal HackerNewsNext.js

© 2025 TechEcho. All rights reserved.

How Developers Stop Learning: Rise of the Expert Beginner (2012)

672 pointsby DerCommodorealmost 5 years ago

63 comments

dorkwoodalmost 5 years ago
I feel like a lot of people here are missing the point of the article.<p>I&#x27;ve worked with several &#x27;expert beginners&#x27; over my career. They think they&#x27;re near the skill ceiling, but they&#x27;re actually much closer to the bottom. They rose through the ranks despite not being particularly great at their jobs, and now find themselves having to indoctrinate others into their way of doing things. Any suggestion on how to improve the process is usually met with some form of &quot;that&#x27;s not how we do things around here&quot;, since the expert beginner feels threatened.<p>Preventing yourself from becoming an expert beginner doesn&#x27;t mean you have to dedicate all your spare time to learning 200 different technologies, as some here have suggested. It&#x27;s more about accepting that learning is a life-long practice. Knowing that less experienced coworkers still have things they can teach you. Understanding that there is still so much out there for you to learn, and being humble about that fact.
评论 #23774038 未加载
netcanalmost 5 years ago
I like these sorts of analysis, whether I agree or not.<p>I&#x27;ve come to believe though, that they need humour. There&#x27;s always a tendency to over-extrapolate, get hung up on typologies which crack under weight and to assume the model is the main thing going on. Humour gives them a productive &quot;playing with ideas&quot; vibe, keeps it honest.<p>In software development, for example, I always think that demographics play a big role. Every decade we get more young programmers than the last. Many older programmers &quot;graduate out&quot; one way or another. The resulting demographics are unusual, with a years of experience pyramid more like the military than most professions.<p>Technology, methods and philosophy change rapidly. This is both exasperated by and causal to the demographics, and the youth&#x2F;pace of the field itself. A lot of software culture has this relationship with the demographics. Maybe 60yo developers are more likely to produce important new things, but they are outnumbered 100-1 by 20-somethings... enforcing youth biases, etc.<p>I think a lot of this essays thoughts on learning might be affected by software demographics. A lawyer, accountant or aviation engineer&#x27;s thoughts on learning and career progression probably encompasses much longer time periods. In software, we think in much shorter timescales. Between the age of 22 &amp; 27, a programmer has progressed through a &quot;career.&quot; Between the age of 22 &amp; 27, an accountant has progressed through a cadetship.
评论 #23779060 未加载
lmilcinalmost 5 years ago
I personally think there are multiple reasons for this situation.<p>* It is fun to learn initially, to see something new working. Once you get something working not many people see fun in spending a lot of time in getting it to work better.<p>* There is huge amount of introductory materials (guides, tutorials, examples) but the amount of available materials falls drastically as you start to progress.<p>* Only some people are able to actually think in abstract terms required to &quot;create&quot; new knowledge based on existing facts. Beginners can advance quickly by &quot;recreating&quot; -- executing tutorials, copying existing code, etc. It is relatively easy to use these as building blocks for a simple application. But as you progress you have to figure out more and more new knowledge, understand underlying principles. This is what many people either don&#x27;t feel comfortable doing or don&#x27;t feel is necessary to do or are just plainly incapable.<p>* It gets more difficult to work with other people in your team as you create knowledge in a given topic. There is tendency to push back when team member tries to introduce something new that is not clearly recreation of accomplishment of somebody else available on the Internet.<p>* Creating new knowledge in the topic is a huge risk in that it is unknown payoff for large amount of honest work. There is not much risk in following existing tutorials, it is pretty much guaranteed that it is possible to recreate accomplishment others did. When you create new knowledge (for example new patterns, principles, guidelines) it is likely you are going to make mistakes. This fact may cause people uneasy and dissuade them from further advancement in the topic.<p>* Getting mediocre in any specific topic is frequently seen as good return on investment. For example, as an architect I would maybe not want to get expert at any of the frameworks I know. I see this as a reasonable tradeoff which allows me to tackle other problems as soon as I think I know &quot;enough&quot; about particular topic.
评论 #23774233 未加载
评论 #23774504 未加载
zubspacealmost 5 years ago
<i>As such, Advanced Beginners can break one of two ways: they can move to Competent and start to grasp the big picture and their place in it, or they can ‘graduate’ to Expert Beginner by assuming that they’ve graduated to Expert.</i><p>I think, that viewpoint is a bit narrow. The example, where the author tells the story how he started bowling the wrong way and reached a plateau, where he could not further progress, is a good one. And I&#x27;m sure there are numerous examples each one of us can tell of own experiences made when learning new skills.<p>In my opinion learning new skills fast is a great skill. And nowadays there are many resources available to us make this easy. But you will always reach a plateau, where further progression gets increasingly difficult. It&#x27;s fascinating how this corresponds to larger patterns like the Gartner Hype Cycle [1].<p>The question is, what do you do when you reach a plateau? Do you invest more time and money? Maybe the skill level suits you well and you don&#x27;t feel a need to progress further? Maybe deeper understanding is not necessary to do your job well? Maybe it&#x27;s better to acquire different skills which you can combine instead of being an expert in one area alone?<p>I think there are many nuanced answers to that question and simply put blame on the expert beginner is not useful.<p>[1] <a href="https:&#x2F;&#x2F;blogs.gartner.com&#x2F;smarterwithgartner&#x2F;files&#x2F;2019&#x2F;08&#x2F;CTMKT_741609_CTMKT_for_Emerging_Tech_Hype_Cycle_LargerText-1-1024x974.png" rel="nofollow">https:&#x2F;&#x2F;blogs.gartner.com&#x2F;smarterwithgartner&#x2F;files&#x2F;2019&#x2F;08&#x2F;C...</a>
评论 #23768428 未加载
评论 #23768095 未加载
ferrosalmost 5 years ago
When interviewing new candidates it&#x27;s interesting to see the difference between beginner&#x2F;mid and seniors. The beginner&#x2F;mid group seem to have a lot more confidence in their skills and not be as aware of what they don&#x27;t know. The seniors seem to be more aware of what they don&#x27;t know and maybe also a little harder on themselves.
评论 #23768004 未加载
评论 #23768443 未加载
评论 #23768149 未加载
评论 #23767999 未加载
评论 #23767981 未加载
评论 #23773503 未加载
评论 #23768021 未加载
kibaalmost 5 years ago
On skill development: I mainly think of it as an exercise in emotional management, just like procrastination, or physical activities, and so forth.<p>It doesn&#x27;t seem to ever become easy for me. I am always running into challenges and difficult obstacles once I overcome the procrastination issue. I am bullhorned about it, so I&#x27;ll eventually get through. That, more than any particular strategy for learning, is the most important in skill acquisition.<p>Another component of skill acquisition is skill retention. You&#x27;ll get rusty when you don&#x27;t practice your skills, and in enough time, you&#x27;ll lose your progress. This is probably more than anything else, a lifetime commitment so that you don&#x27;t lose your progress in the knowledge or skills you picked up, so that in the long run you become better and better over time.<p>Think of it this way: You learned 10,000 useful &quot;stable&quot; facts about the world one year. Next year, you learned another 10K facts. But retention is exponential. Practice it long enough, the facts will last a lifetime.<p>Suppose a person have no strategy for retention. Let say he learned 10K facts, 75% decays away. Next year, he learned another 10K facts, but another 75% decays away. So he retained only 5,000 facts, but you retained 20,000 facts. Obviously, this is contrived, but it does illustrate why colleges and high schools aren&#x27;t very effective. It&#x27;s not that they don&#x27;t teach, it&#x27;s that the students forgot what they learned as soon as they finished a course.<p>I often get interested in a subject matter and then drop it some point. This often result in surface understanding of the subject. Just enough to sound smart. However the knowledge is retained. Should I ever return to a subject, I&#x27;ll retain the knowledge from scratch, as sometime I do.<p>Sometime I was able to keep at a subject long enough to acquire some amount of true mastery.
评论 #23768310 未加载
barrkelalmost 5 years ago
I don&#x27;t really buy the analogy.<p>Writing software is a bit like playing multiple sports. You can be good at one thing and poor at another, and as a result do great work on one project and be mediocre on another.<p>Writing code in the small, optimizing; architecting for change; architecting for scale in development; architecting for scale under load; architecting for scaling out vs up; all different skills.<p>Writing code functionally, vs procedurally, vs message oriented. Writing code with control flow vs data flow, and toggling between them. Crafting abstractions vs composing them. Many small parts put together elegantly vs one straightforward transparent monolith. Some skills are alternates, you can go either way and get as good results.<p>There are people who only know a few things. But on a suitably scoped project, that may be fine.
评论 #23769887 未加载
评论 #23775448 未加载
评论 #23768436 未加载
评论 #23768293 未加载
ChrisMarshallNYalmost 5 years ago
I’m not sure the “10,000 hours&#x2F;5 years” rule is a particularly relevant one, these days. Tech mutates so quickly, it&#x27;s near impossible to become an &quot;expert.&quot; Also, many developers are...how can I put this...<i>a wee bit obsessive</i>. It’s quite possible to hit 10K hours well before 5 years.<p>I liked the analogy about the quirky bowling style.<p>That has happened to me -several times.<p>I’m primarily self-taught in most of my tech. It has tended to result in very highly-developed, but narrow, skillsets. Not necessarily a bad thing, but “brittle.” It has happened so many times, that I no longer feel that I am an “expert.” I am now “experienced.” At least the first five letters match.<p>But it has been a long road to where I am now. Humility has been forced upon me, and I now have a <i>lot</i> of “narrow skillsets,” to the point that they inform each other. For example, a lot of the stuff I did in PHP has helped inform my work in Swift, and vice-versa.<p>I’m choosing to specialize in a specific discipline and tech stack, which, just by itself, gives me a lot to learn. I am working to develop a “broad base” in a small-ish venue, with a lot of “sharp peaks.”<p>It’s really humbling. The more I know, the more I know I don’t know. Also, since I am constantly trying out stuff I don’t already know, I’m a perennial “n00b.” Usually, this manifests by not always being aware of the jargon (I know the tech, but not the name). This may result, I suspect, in my being treated rather shabbily by folks in the field (It may also have to do with my age. I have found that the way people treat me changes radically, as soon as they find out that I&#x27;m &quot;long in the tooth,&quot; so I now make it obvious to avoid that). This has helped me to just keep my damn mouth shut, and open it only to eat my humble pie.<p>I write about that here: <a href="https:&#x2F;&#x2F;medium.com&#x2F;chrismarshallny&#x2F;thats-not-what-ships-are-built-for-595f4ae2c284" rel="nofollow">https:&#x2F;&#x2F;medium.com&#x2F;chrismarshallny&#x2F;thats-not-what-ships-are-...</a>
评论 #23769660 未加载
greatgibalmost 5 years ago
As said in one comment, PART2 (link at the bottom of the page), is where this begin to be added value compared to the existing theory.<p>That being said, very great article that describe well and nicely what I have personally experienced in a sme company that was bought by a big tech group at some point: - when I arrived, the core team was already there with some having personal ties. A few beginners that took the mediocre manager as mentor, that took himself his manager as mentor - they learnt by themselves, mostly there, they were responding to diverging opinion with anger. - over the years, a few &#x27;outsiders&#x27; arrived and try to change things by showing the problems and explaining that outside world do differently. - but each of them had to face the seniority argument reinforced by the group effect to justify that they can&#x27;t be wrong. (Listen, we are 3, you are 1, it means that we are right and you are a pain in the ass to think otherwise. Doesn&#x27;t count that you say that out of the company are unanimous on the subject...)<p>The worst (almost funny) case I remember was that:<p>- Person 1 (p1) and person 2 (p2) have a disagreement on how something has to be implemented.<p>- p1 is the boss favorite, so he is always right... so his solution will be implemented. No one listen to p2 that says that it is an inefficient idea, possibly problematic and that is why no-one does it this way outside. (No-one? In fact they found one case over 100 of outside projects that did that, so that gave them confirmation that they were right...)<p>- p1 engine solution is implemented and p2 has to do a component working with that, but that does not work well at all, very slow for basic operations, lots of unexpected deadlocks and issues like that. Another manager complains about the issues.<p>- P2 decides to give a try reimplementing the engine with his solution. That is completed is no time and it is excellent: performance x1000, no lockup, no more issues with basic operations.<p>- results are shown to mediocre manager. But instead of accepting and going this way, he blocks the thing and can&#x27;t accept that his favorite was wrong. So says that there should be a bug in P1 implementation and give him as much time as needed to test and look at it.<p>- after 1 months, P1 did everything he could with his solution to fix it without using the solution of P2. He comes proudly with his engine is now 10x faster than initially.<p>- but so, 10x vs 1000x is a no match, and P1 solution was still rigged with issues. So it is finally P2 solution that is used &#x27;out of choices&#x27;. BUT... as manager still does not accept that he and P1 were not right. He said: ok we use P2 solution, but you will have to embed and support P1 implementation in the final product. Not to be used but maybe one day...<p>- conclusion of the story? Evaluation time arrived. Did P2 got a good eval? That would be logic, he saved the product, gave an important perf and stability boost to the solution. But no, he got the worst! Manager said that P1 had to take depression pills because of P2... Not because his solution was wrong and couldn&#x27;t accept, learn and improve from it. Buuuut: P1 got the maximum grade!
评论 #23895394 未加载
cosmodiskalmost 5 years ago
I think the main problem is that most businesses are more than OK with mediocre developers. There&#x27;s only a small number of companies on this planet where boundaries beimg pushed to extremes and it requires the top devs to keep going further and further. It&#x27;s like football: there are lots of kids playing football,but we only need a few hundred,maybe a thousand that are at the very top of it. And to get and to keep yourself at the top does require very different mental capabilities than to get from a mediocre one to a good developer.
评论 #23771714 未加载
cjfdalmost 5 years ago
Identifying the good developer with the frequent job hopper and the expert beginner with the developer who stays at the same place seems rather unfounded. I have also seen the job hopper who left just before it became clear that his architecture was actually not all that great. Also, wanting to use the standard stuff vs. rolling out your own is more a thing of incentives. If you are a frequent job hopper it is nice to learn something standard. If you stay at the same place you will have to suffer from the standard boilerplate that the not-so-great framework requires and that has to be typed over-and-over. It is more a matter of incentives than that one thing is necessarily better than the other, I think. One great advantage of the programmer who stays is that his decisions are backed by skin-in-the-game. S&#x2F;he has to suffer through the consequences of his choices.
austincheneyalmost 5 years ago
&gt; As such, Advanced Beginners can break one of two ways<p>Perhaps a more clear way to think of that is in terms of comfort and bell curves. The left extreme of the bell curve is easy to both identify and understand for anybody beyond the left end. Those are the people at the low end who perform below accepted baselines.<p>Less well understood are people at the right end of the bell curve, who drastically out perform other developers. In all objectivity the people at the right end of a bell curve have as much as in common with the median population swelling into the middle of the curve as the supposedly incompetent people on the left end.<p>Think of this in terms of risk and popularity. When you are below the middle of the bell curve everything to the right of you is better performing. You can increase your performance by moving closer to the middle of the curve by doing what is popular.<p>Once you get to the middle of the curve you have to make a firm decision: remain comfortable in your current posture and let popularity dictate your approach or take risks to further increase performance beyond the population median. In that regard the populations at both the extreme left and right ends of the bell curve are doing things that are extremely unpopular. <i>You cannot become an expert without fully embracing that reality.</i><p>An expert beginner is a person at the median of the bell curve or just to the left of it. They have mastered their skills to that point and refuse to make changes or take risks necessary to advance further.<p>As a front-end developer I frequently encounter expert beginners. People who have mastered some framework&#x2F;convention, but doesn&#x27;t really understand how their technology really works and are hostile to improvements that don&#x27;t make use of their favorite framework&#x2F;convention. To outside observers the expert beginner is clearly identifiable as performance is objectively measured with numbers without regard for approach.
gerlandalmost 5 years ago
I don&#x27;t really buy the &quot;expert beginner&quot; thing. How does it relate to having the &quot;T-shaped&quot; skills? One is the frowned upon and the other is desired for some reason.<p>The reality of programming is that most often than not you do not need to be an expert to do a job well. I would even say that being an expert programmer is all about sticking to only basic things. The more you try to be smart and &quot;on the edge&quot; the more you or someone who inherits your code will fail. If I would get 1$ for every trendy abstraction or framework, then I would not retire, but probably could buy a new PC or something.<p>IMHO it all boils down to ego trips. Everyone thinks he is the superstar, ninja or 10x and everyone else just a poser. &quot;I&#x27;m the smartest one&quot; should be the motto of IT. If you think that you are the one that can push the whole community forward then you are probably delusional. I think I&#x27;m a moderately advanced developer, but some of the people that I met along the way were just crazy smart, highly productive and - here is the surprise - nowhere near the top. This delusion of grandeur is especially common in people that are pampered in the business. If I would name them, then I would be instantly downvoted, but just stop and try to imagine what people I mean. I&#x27;m guessing you won&#x27;t have any problem.<p>In the end, your project does not need you to be an expert, your team does not need it, the business does not as well. Only your ego.<p>Long live the &quot;expert beginner&quot;!
评论 #23779400 未加载
评论 #23770244 未加载
plorntusalmost 5 years ago
I feel like that article took way too long to get to the actual point of it then unfortunately abruptly ended as soon as it got interesting.
评论 #23767841 未加载
irrationalalmost 5 years ago
My problem is that I’m expected to learn so many things that I never have time to become an expert in any of them. Html, css, sass, JS, Vue, Vue router, vuex, react, other react libraries, lodash, jest, webpack, Python, node.js, Java, sql, Oracle, Postgres, bash, regex, docker, kubernetes, aws, azure, etc. ad infinitium.
评论 #23768620 未加载
评论 #23769694 未加载
评论 #23769566 未加载
ragonaalmost 5 years ago
I didn’t really find anything I felt like specializing in for the first decade-ish of my career. I was working on games, I don’t think 3D math is that cool, and I wasn’t excited. I was tired of coding games over and over. I don’t think I was an expert beginner but I wasn’t an expert in anything I wanted to continue doing.<p>I took a break to be a manager for a while, which turned out to both be an incredible learning experience AND enough pressure relieved from the daily code grind that I was able to rekindle my passion for code.<p>Started writing a lot outside of work, realized I really like cryptography, studied that, became competent enough to even figure out what TYPE of beginner I want to be, etc. it’s very satisfying.<p>I’m around four years into that journey now, I’ve returned to a coding path where I get to actually learn while building, and I’m excited.<p>The expert beginner is a surprisingly easy trap to fall into. I also think we do this TO people when we trap them in a role and give them very little flexibility in execution.<p>They will begin to specialize in doing a bad thing well without understanding what they’re doing, especially if they aren’t given mentorship.
评论 #23773520 未加载
gitgudalmost 5 years ago
Similar to the rise of the StackOverflow programmer. You can get pretty far just by Googling error-codes and brute-forcing a problem in a domain without any experience (I should know).<p>Maybe not the best way to learn, but in such a technologically complex world, it can sometimes be more effective...
评论 #23768687 未加载
评论 #23769295 未加载
tarsingealmost 5 years ago
What is a good developer? Isn&#x27;t there more than one axis? For my case over the years I have honed my skills at problem solving, seeing the big picture, and finding the most efficient technical solution from a business perspective (not GAFAM scale obviously, but that&#x27;s the exception). As a result, I can save companies a lot of time and money because I will help reshape the problem and rework the scope to find the max added value &#x2F; work ratio, to deliver in days a working solution, instead of a big year long project with all the overhead. My productivity is high because I know where to cut the crap.<p>More than once I have seen a peer or a whole engineering department of brilliant people going down a technical rabbit hole for weeks for intellectual satisfaction, where instead I will just take a step back, walk to the manager and try to work a different take for a solution that can be implemented in a few hours&#x2F;days even if the business goal is slightly moved.<p>Yet I&#x27;m definitely not a good professional software developer in terms of code &quot;quality&quot;, and don&#x27;t consider myself very smart compared to my peers.<p>Edit: formating
评论 #23768838 未加载
评论 #23768528 未加载
评论 #23768806 未加载
评论 #23770797 未加载
评论 #23771701 未加载
评论 #23770032 未加载
评论 #23770676 未加载
ChrisRRalmost 5 years ago
I work with an expert beginner and I don&#x27;t know how he&#x27;s survived. He&#x27;s got about 30 years of experience, but writes code like he&#x27;s got 1 year of experience.<p>His code has absolutely no sense of quality, doesn&#x27;t employ any sort of standard design patterns or style, has no semblance of architecture and is an absolute hacky rats nest of code that falls apart with any change because of how interdependent it is.<p>The other day I was sent some of his updated code, which had no version control and had randomly added an extra 150 files to the project. It turns out the majority of those files where duplicated from elsewhere in the project and apparently it was my job to find where the changes were among that mess.<p>It&#x27;s like he learnt to program decades ago and then never opened a book or looked at anyone else&#x27;s code since.
评论 #23768642 未加载
评论 #23768640 未加载
评论 #23769054 未加载
评论 #23768754 未加载
评论 #23768928 未加载
评论 #23769010 未加载
评论 #23768634 未加载
Garlefalmost 5 years ago
I think blaming this all on learners not realizing their missing potential is a bit one sided.<p>Other influences:<p>* Skill level of coworkers * No time is dedicated by the team to abstractions &#x2F; refactoring due to deadlines, or personal preference etc. * The technology being used is limiting or used in a limiting way.<p>If you never push your boundaries you&#x27;ll never get better. Going to 100% one time will have a lasting effect. If you instead only go to 80% all the time you&#x27;ll only get better at doing a mediocre job.<p>However, the goals might be misaligned here: Your employer and coworkers might not be interested in your personal growth. Instead they want you to &quot;Get stuff done.&quot;
zoomablemindalmost 5 years ago
I find the article while thoughtful and provoking, paints a myopic view of self-advancement. The analogy with sports is what throws it off. Sports can be individual and could be team-based. There&#x27;s an importance to individual skill, no doubt, but the team apect is what lets one not only assess own standing, but have a chance at advancing it without the adversarial pressure. If you choose to retool, the team would pick up the slack meanwhile until you&#x27;re back (hopefully stronger).<p>The skill degrees indeed are relative, and in the field of programming are dynamic. Of any one skill to put in permanence is perhaps an open-mindedness. It is a readiness to learn, not much an ability to master.<p>Lots of excellent programmers don&#x27;t stop learning, they just discover the wisdom of &#x27;good enough for the time-being&#x27;.<p>Expertship is lonely, beginnership is open an dynamic. The author projected the whole skill advancement spectrum onto the single grade of Beginner, as if beyond Expert lied a void or infinity.<p>I believe, paradoxically, beyond Expert is ... a Beginner. Either by humbleness, or by need to discover a new field, or by age, or boredom, or wisdom.<p>Programming has to be a team activity. If you happen to handle a project part by yourself, your future self or someone to work on your code after you is your current team.<p>If you&#x27;re on the team already, then you keep learning from your mates as long as you let your mind stay open to it.
aneutronalmost 5 years ago
Or maybe they stop learning because at some point, you realize your employer doesn&#x27;t give two shits about doing incremental changes to your infrastructure &#x2F; code, let alone breaking changes, but instead pursues paying outside contractors to do broken shit you&#x27;ll add the pile of things to fix.<p>Or maybe that&#x27;s just me. Also, I&#x27;m not going to work on mathematical proofs for something good, just to see my work disregarded because it&#x27;s &quot;too complicated&quot;.
imnotlostalmost 5 years ago
Developers are supposed to do all this learning on their own time as well, right? No budget or time for training. In fact, why don&#x27;t you do some overtime paid in pizza?<p>Learn new stuff at home on your own time, put it on github, it&#x27;ll be fun, ignore your family and your friends.<p>And the helpful comments here for someone who is doing 12-hour days is to meditate and go for a walk?<p>Work 7 hours and go home, your life will be better.
Discombulatoralmost 5 years ago
While the topic is interesting, I don’t think the analysis presented in the article series (at least in the first two articles) is particularly compelling.<p>For one, it relies much on hypotheses about internal though processes, which makes it basically unfalsifiable. Then the author is in my view shooting himself in the foot with the bowling analogy, namely by describing how he noted that he didn’t improve anymore and went to ask a colleague for advice. How would the same not be possible or even likely for the “expert beginner”?<p>All of this is much more easily and briefly explained by motivation - for many people in technology, technology is simply not a passion! For them it is just a tool and like also the article mentions, there are few reasons in many companies to spend more time on perfecting your craft - in fact, it might be strictly worse than building career-enhancing relationships. This is especially true as someone not in a technical position is often not able to assess the quality of the output.
blickentwapftalmost 5 years ago
If you are a developer, what is the last significant thing you learned, and when did you learn it?
评论 #23768635 未加载
评论 #23768745 未加载
评论 #23768307 未加载
评论 #23768664 未加载
评论 #23769191 未加载
评论 #23768500 未加载
评论 #23768932 未加载
评论 #23768081 未加载
评论 #23773547 未加载
ivanhoealmost 5 years ago
The only problem here is that building things, unlike bowling, is a team effort, and also goals are very different, you don&#x27;t win the game by having the highest score in the end. IMHO big question is if it&#x27;s worth to invest into &quot;getting your score over 160&quot; in terms of benefits for you and&#x2F;or company? Can that time be better used? Will your project benefit more from moving your bowling from 160 to 200 - or you can get your role covered just fine with 160, so perhaps invest time instead into getting at least 1600 ELO in chess which will be needed on the next project, and will also give you a wider perspective?
heisenbitalmost 5 years ago
Any discussion of software competency that does not take into account the rapid aging of some skills is incomplete.
评论 #23768548 未加载
mgrennanalmost 5 years ago
After 40+ years as in electronic, software developer, OS and App, Networking, SysAdmin, DBA and DevOps I see it all as a multi discipline. Knowledge in Electronics, CPU design, Compiler development, OS design, communications, Business management and user interfaces all relate and a &quot;Rock Star&quot; would need to be an expert in them all.<p>Most Dev&#x27;s stop with App dev and business design. Some go on to UI or compiler performance. System a little and communications and electronics almost never.
评论 #23770852 未加载
ErikAugustalmost 5 years ago
People respond to incentives.<p>As the author puts it, many a developer gets hired and eventually they &quot;entrench themselves into some niche in an organization and collect a huge paycheck because no one around them, including them, realizes that they can do a lot better&quot;.<p>In my experience, that is what does happen. There is no incentive to do better, and the paychecks in IT happen to be pretty large.<p>I progressed the most as a software developer when I wanted to be hired again after striking out on my own for a bit.<p>What I learned from striking out on my own was that my software development knowledge and abilities may have worked in previous contexts but not where I wanted to be as a next step of my career. While I could have been promoted at a previous job that wouldn&#x27;t have proven anything on the open job market. This is probably where a lot of dissonance often occurs. People are Senior or Lead developers at one place for a long time then suddenly are out of a job and cannot find another one.<p>So I worked hard to improve in a number of ways because I was highly incentivized to do so - there was no &quot;current position&quot; to fall back on.
honkycatalmost 5 years ago
This article addresses a very particular person who definitely does exist. Expert beginners are absolutely a thing and things have only gotten worse with the &quot;HIRE EVERYBODY! NO TRAINING REQUIRED&quot; approach to hiring a lot of shops moved to.<p>I had not experienced it until the past year. If this article does not resonate, if you have not worked with one, count yourself lucky.<p>I am regularly astounded by the lack of extremely basic skills I have seen in the places I have worked recently. For the love of god, just read a single book or take a single class on software development.<p>People argue: &quot;Well, most shops don&#x27;t really need good developers.&quot; I call BS on this. Every place I have worked at are trying to make money and keep the team from getting canned, and a bad developer will take you two steps back for every one step forward.<p>There was a person at my last job, nobody knew why they kept him around. He had a good 10 years on most of the team, but his code was easily the lowest quality, and he constantly fought with the rest of the team around attempts to improve code quality.<p>We hated him. He was totally stale and had given up on self improvement. We wanted him GONE. What happened? Most of the team quit and he is still there.
netcanalmost 5 years ago
I think there is long term culture clash between old and new ways of learning, in the &quot;over a career&quot; sense.<p>The old way is the formal, with external motivations and structures. Maybe there&#x27;s a curriculum, like accountancy has. Maybe there&#x27;s a coach, like in sports. One can spend a long time in the &quot;infant stage,&quot; learning by mimicry.<p>A young karateka spends years practicing motions in the air, with form carefully observed and corrected by a teacher. This lets learners access the knowledge of karate as a whole, without needing an intuitive understanding of why this elbow must point that way while performing kick two in exercise X.<p>To jive with the author&#x27;s bowling analogy... Imagine a child bowling with just a ball. No pins. No aley. A teacher corrects form: posture, the swing of the arm, the final position. Once the child starts bowling for real, all their habits will be good. The known deficiencies of poor form are avoided, and the risk of hitting an &quot;expert beginner&quot; dead end is low.<p>This kind of formality is only possible when the domain is well known, and &quot;correct form&quot; is well understood. I suspect that these systems require generations to build. They also run the risk of devolving into ritual, superstition even.<p>The informal, more autodidactic culture does risk an &quot;expert beginner trap,&quot; a premature peaks in skill that requires formal (or intentional) training to defeat. OTOH, &quot;expert beginner&quot; is not just a trap. It&#x27;s a useful goal, for a lot of situations.<p>If you are going to fight the bully next week, karate is not a good answer. Those highly refined skills have little intrinsic short term roi.
OJFordalmost 5 years ago
Judging from the &#x27;7 years ago&#x27; comment &#x27;dates&#x27;, and the article&#x27;s &#x27;30 Sept&#x27; &#x27;date&#x27; (!), this is (2012)?
oldandboringalmost 5 years ago
I&#x27;m going to risk echoing what other like-minded contrarians here have posted. This essay makes some good observations about what happens to developers in their careers, but colors those observations with opinions about what&#x27;s good and bad. And, as is usual in the developer community, continuously learning new technologies and layering in more &quot;best practice&quot; structure (presumably in one&#x27;s own free time) is always king when it comes to these folks.<p>It&#x27;s hard not to read this and sense a bit of bellyaching about how the market for software engineers isn&#x27;t a pure meritocracy where those who are using all the latest tools with pitch-perfect architecture are the only ones who get hired and promoted. And it seems to totally ignore the real world in which legacy software, with all its warts, does exist and can&#x27;t be thrown out.
adverblyalmost 5 years ago
Good article but I disagree.<p>&quot;Bowling is like Software&quot; does a good job at pointing out a common problem(You can develop and get stuck using a style which has a lower ceiling than other styles).<p>I still think &quot;Bowling is like Software&quot; is a bad analogy though.<p>Bowling is a one-dimensional task: Its the same problem every time, so some styles will likely have much higher ceilings than others. Software is far more complex: some styles work well for some problems but poorly for others. If there is actually a generic fix-all style, its likely very abstract, difficult to grock, and probably involves a lot more math than we&#x27;d like to admit.<p>So I don&#x27;t think theres anything wrong with getting good at one style, even if it has a low ceiling because even if you learn another style later, you will probably want to go back in your toolbox at some point in the future to mix in some of the original style.
评论 #23773467 未加载
softwaredougalmost 5 years ago
It feels like self-admitted beginnerism is actually the mark of a great developer (not assumed expert). Regardless of whether the “expert” is genuinely earned or not.<p>Indeed this is the idea behind the beginners mindset[1], where we assume our knowledge and experience may be faulty. That we have to unlearn our skills to make a further leap. That when you assume you’re an expert, you’ve already lost.<p>So I tend to question the Dreyfus model in general. I want to see how capable people are at getting skills, but also how readily they can discard hard won skills. Similar to a sunk cost trap, we can needlessly hold onto our skills and hesitant to think we need to let them go and rethink the whole approach.<p>[1] - <a href="https:&#x2F;&#x2F;en.m.wikipedia.org&#x2F;wiki&#x2F;Shoshin" rel="nofollow">https:&#x2F;&#x2F;en.m.wikipedia.org&#x2F;wiki&#x2F;Shoshin</a>
评论 #23773561 未加载
monksyalmost 5 years ago
1. It&#x27;s a lack of discipline (If it&#x27;s anything from the testing post we saw yesterday)<p>2. Aggressive pushes to deliver over creating something solid or experimenting with different archs<p>3. The selection process doesn&#x27;t look for experience.. they have been looking for leetcoders that haven&#x27;t changed since college
Peckingjayalmost 5 years ago
Links to previous discussions:<p><a href="https:&#x2F;&#x2F;news.ycombinator.com&#x2F;item?id=11327669" rel="nofollow">https:&#x2F;&#x2F;news.ycombinator.com&#x2F;item?id=11327669</a><p><a href="https:&#x2F;&#x2F;news.ycombinator.com&#x2F;item?id=19467367" rel="nofollow">https:&#x2F;&#x2F;news.ycombinator.com&#x2F;item?id=19467367</a>
bobobob420almost 5 years ago
In my opinion experienced developers are mostly pretty dumb even at top firms. Yes they are GREAT at the particular thing they have invested the most into labeling themselves but are often stuck in some tunnel vision or just do not care to learn new things. Many young developers are eager, learning multiple technologies&#x2F;languages at once, work across back-end, front-end, network, dev ops..to be a successful new developer the wall is much much higher than it was for developers 20 years ago. These old guys can&#x27;t do much tbh and are so slow at adapting, they don&#x27;t even have excitement in meetings or anything. So boring. You can do what you want in life but don&#x27;t complain if you are replaced.
deltron3030almost 5 years ago
Developer = programmer, or are devs expected to have more general and higher level big picture knowledge?<p>Is every carpenter without interest in furniture design an expert beginner, or just a carpenter?<p>Aren&#x27;t developers who aren&#x27;t into design&#x2F;business just programmers? Why is this bad?
twicetwicealmost 5 years ago
This is a really neat article. I feel like just this week I reverted from Expert Beginner to Advanced Beginner—or maybe glimmers of Competent—as working on my current project has revealed to me just how much I don&#x27;t know about what I thought I knew well.
tracerbulletxalmost 5 years ago
This is a valid interpretation of a trap that people can fall in to but there is also a positive interpretation of being an &quot;expert beginner&quot;. Developers encounter so many new technologies at such a rapid pace over their careers, especially recently. People who are constantly trying new technologies at a shallow level can have access to more tools to solve problems and be successful in a rapidly changing environment as long as they don&#x27;t over do it, and narrow their scope to relevant topics that support each other. I think there is a line to walk between falling into a lack of mastery, vs not absorbing new things at a beneficial rate.
pontifieralmost 5 years ago
This hits hard. I know that I&#x27;m missing some truly fundamental techniques in my development such as testing and ORMs, but I can&#x27;t seem to bring myself to take the massive steps to abandon the way I&#x27;m doing things now.<p>Every time I try to start doing things &quot;The Right Way&quot; I end up getting nothing done. In frustration, I revert back to my old technical debt building ways just to try to move forward at all.<p>-side note- I didn&#x27;t even know it was possible to bowl without sticking your fingers in the holes... it&#x27;s almost as absurd as not doing any automated testing.
jartalmost 5 years ago
Sounds like fake it until you make it. People, especially self-taught ones, aren&#x27;t going to pursue something if they believe they&#x27;re bad at it. Be nice.
marcus_holmesalmost 5 years ago
This really hit me.<p>Am I an Expert Beginner suffering from Dunning-Kruger and delusions of competence?<p>Or am I an actual Expert suffering from Imposter Syndrome?<p>I&#x27;m working as tech co-founder in a small team with junior devs, and I do some things &quot;differently&quot; for what seem to me to be good reasons.<p>How do I tell?
评论 #23768288 未加载
Tomis02almost 5 years ago
&gt; On the other hand, the least talented developers are more likely to stay put since they’ll have a hard time convincing other companies to hire them.<p>Terrible fallacy on so many levels. &quot;I can&#x27;t convince you to hire me, therefore I&#x27;m bad&quot;. &quot;I can convince you to hire me, therefore I&#x27;m great&quot;.
raiflipalmost 5 years ago
I&#x27;ve dealt with whole teams of these kinds of people. They also get extremely defensive about anything they don&#x27;t know. Even worse, this was particularly the case around proper testing. Suffice to say the team committed a lot of bugs to production.
SMAAARTalmost 5 years ago
Expert Beginner? That&#x27;s not just a Developers&#x27; phenomenon, it&#x27;s actually more prevalent in business where &quot;I have X years of experience....&quot; what if they have been doing it wrong for x-years?
Sniffnoyalmost 5 years ago
(2012)
评论 #23768625 未加载
dadogealmost 5 years ago
Most “Super Senior Principal” engineers I see at larger companies are ones that have been there for 5+ yrs, so I disagree that the best engineers always run to greener pastures.
评论 #23772370 未加载
courtfalmost 5 years ago
I remember this one, there are lots of good articles on this blog. This one is a little aggressive, but this is a real phenomenon. In many companies, styles and expectations fluctuate too much for anyone to get comfortable for long. Lots of others move glacially, and within those walls, the outside world can barely be heard.<p>I&#x27;ve bounced around quite a bit myself, but some of the best work I&#x27;ve done has been in situations where I could have slacked off and phoned it in. That was typically prevented by the opportunity to perform challenging work that allowed me to learn, not by fear of falling behind some imaginary peer.<p>The problem with many workplaces is that challenging, interesting problems are few and far between and that is by design. Why take on the risk to the business by having technical knowledge in-house to solve the hard stuff? It&#x27;s expensive, and large chunks of that investment can just walk out the door. Most companies would happily pay for solutions from other businesses that specialize, and then ask devs to glue these mismatched pieces into a semi-cohesive whole.<p>This sort of glue-work is ubiquitous, even in companies that ostensibly specialize in making their own software. How much time is spent wrangling all those amazing, productivity-enhancing dev tools that have proliferated? The goal is typically to offload work for a fraction of what it costs to keep a dev employed. New businesses are cropping up all the time trying to sell tools to the big boys, so they can in turn keep their devs focused on core competencies. The companies that specialize in tooling of course all sell to each other as well, it&#x27;s a little bit of a cartel, but this endless cycle of tool churn is nothing new.<p>If you approach this environment as a newbie, and you are concerned about becoming an expert, it&#x27;s likely that you&#x27;ll only make progress on that goal in fits and starts. Companies grow, job roles become both over-specified in their requirements and narrower in their responsibilities, and all the while you are expected to learn new tools that allow your employer to save on skilled labor. It&#x27;s rare to find a job where mentoring and career advancement are given genuine care. Employers have an incentive to keep employees tuned for specific, ever-narrowing roles.<p>One of the few consistent places I&#x27;ve been able to find learning opportunities has been in start-ups. The overarching trend is the same there too, but at the beginning those roles are not yet so clearly defined and you can bite off as much as you want. You probably won&#x27;t be rewarded for doing so, and it&#x27;s a bit of a crapshoot, but it is one small advantage to those environments.
kuharichalmost 5 years ago
Prior comments: <a href="https:&#x2F;&#x2F;news.ycombinator.com&#x2F;item?id=11327669" rel="nofollow">https:&#x2F;&#x2F;news.ycombinator.com&#x2F;item?id=11327669</a>
classics2almost 5 years ago
Hiring is not a meritocracy and programming is not bowling.
HugoDiasalmost 5 years ago
Not sure if its just me but its very hard to read this website font. Had to bookmark and read it on Pocket.
brianolsonalmost 5 years ago
Some people have 10 years experience. Some people have the same year of experience 10 times.
musicalealmost 5 years ago
This essay seems to be short on specifics.
ai_ja_naialmost 5 years ago
Very lucid analysis, nice piece
Amlan123almost 5 years ago
From india
Amlan123almost 5 years ago
Hii
knorkeralmost 5 years ago
I really hate it when articles exactly date their stories, but don&#x27;t provide a year.<p>&quot;Sep 30&quot;, this one says. Hmm… can&#x27;t be 2019, because I read this years ago, I&#x27;m sure.<p>The only indicator of year I could find is that the <i>comments</i> to the article are 7 years old.
评论 #23768272 未加载
评论 #23768255 未加载
评论 #23771461 未加载
评论 #23768289 未加载
评论 #23768292 未加载
评论 #23768960 未加载
microcolonelalmost 5 years ago
I think that there&#x27;s often something simpler going on here. Some people are simple and small-minded, they simply do not enjoy learning new technical knowledge and skills, and would rather run what they have to failure even if it means losing out on a lot of income.<p>A fine example of this is a new hire getting anxious and defensive because the git branching strategy at the company isn&#x27;t the branded one they&#x27;re accustomed to (e.g. git flow).
one2knowalmost 5 years ago
Bleh. All I see here are all the same old ageism tropes and noob programmers trying to rationalize their age bias.
r34almost 5 years ago
Maybe developers stop learning because they realize that that to learn how to do the same thing with 167 technologies is not a real development. Maybe they realize (they should) that self-development should be we well balanced, so after programming workday they should invest their time into sports and work with their emotions and take care of interpersonal aspect of their lives.<p>The older I am the more I&#x27;m convinced that development is not individual thing - it&#x27;s a team sport.<p>Hey, company: divide your workday into 4h work for external projects and 4h work for team development.<p>Smart, mature developer, will realize that the most inhibiting phenomenon for him is usually the job itself.
评论 #23769321 未加载
评论 #23771382 未加载
评论 #23769650 未加载
评论 #23769287 未加载
评论 #23769495 未加载
评论 #23770084 未加载
评论 #23769713 未加载
评论 #23770349 未加载
评论 #23770031 未加载
评论 #23769346 未加载
评论 #23769438 未加载
评论 #23772471 未加载
评论 #23772986 未加载
评论 #23770372 未加载
评论 #23769782 未加载
评论 #23769278 未加载
评论 #23772112 未加载
评论 #23772799 未加载
评论 #23769268 未加载
评论 #23769946 未加载
评论 #23770751 未加载
评论 #23770974 未加载
评论 #23771364 未加载
geuisalmost 5 years ago
Look Mr Blogger, take this in the kind hearted intent it’s meant by a 40yr old engineer who doesn’t have time for bullshit anymore.<p>Get to the point, fast and quick.<p>I’m sure you have many valid and interesting points of view about your job, experiences, and wants. I’m interested to hear about them. You could offer some unique experiences I can learn from or maybe there’s some tidbit I can offer you.<p>But unless you learn how to get to the point first, I don’t care. Even now after 3 minutes of perusing your entry I’ve lost any sense of what it was about.<p>To finish up, I’m not trying to be evocative, negative, or anything. I just want to encourage better ways of writing, thinking, and publishing.<p>Always consider your readers first. They don’t have as much time to parse what you write as it takes you to write it.
评论 #23768070 未加载
评论 #23768260 未加载
评论 #23768559 未加载
评论 #23768302 未加载
评论 #23768650 未加载
评论 #23768044 未加载
评论 #23768501 未加载