TE
科技回声
首页24小时热榜最新最佳问答展示工作
GitHubTwitter
首页

科技回声

基于 Next.js 构建的科技新闻平台,提供全球科技新闻和讨论内容。

GitHubTwitter

首页

首页最新最佳问答展示工作

资源链接

HackerNews API原版 HackerNewsNext.js

© 2025 科技回声. 版权所有。

Ask HN: Reading material on how to be a better software engineer?

388 点作者 OneOffAsk超过 2 年前
I’ve gotten to be quite good at the actual coding part after a decade or so of programming. I’m not looking for better code practices, although I’ll obviously still learn and grow there.<p>What I’m seeking is reading material regarding how to manage project scope, be better team member, converting asks to deliverables, managing expectations from management, enabling team members by opening communication channels across teams, time management, etc.<p>Any suggested reading material? Preferably books, but excellent blog posts are welcome.

52 条评论

markshead超过 2 年前
A few books that I&#x27;ve found useful:<p>The Goal - Eli Goldratt - It is a novel about optimizing a factory, but it is immensely valuable in thinking through what are the actual constraints on your team&#x27;s ability to deliver software and how do you fix it without making other things worse. The Phoenix Project is kind of a modern retelling, but I&#x27;d start with The Goal.<p>The Principles of Product Development Flow - Reinersten - Great for thinking deeply about how you deliver value through your system and the tradeoffs you are making in what you choose to focus on next. Once again it isn&#x27;t specific to software, but very relevant.<p>The 5 Dysfunctions of Teams - Lencioni - Common team problems and what to do instead.<p>Influence: Science and Practice - Cialdini - How to get people into agreement so you can move forward--a skill that can be used for both good and evil.<p>The Little Schemer - Friedman and Felleisen - It is kind of hard to describe why this would be useful, but I felt it made me think more deeply about what it means to program a computer in ways that indirectly supported the topics you mentioned. Or maybe I just happened to work through it at a point in my life when I was growing in those other areas too.
评论 #33861120 未加载
评论 #33891489 未加载
bitsofawesome超过 2 年前
The two most useful books I have read: Code Complete by Steve McConnell - Really covers how to be good at the craft of writing programs and constructing software. <a href="https:&#x2F;&#x2F;www.amazon.com&#x2F;Complete-Microsoft-Programming-Steve-McConnell&#x2F;dp&#x2F;1556154844" rel="nofollow">https:&#x2F;&#x2F;www.amazon.com&#x2F;Complete-Microsoft-Programming-Steve-...</a><p>The Effective Engineer by Edmond Lau - Covers how to focus on what you work on based on the leverage it provides you. <a href="http:&#x2F;&#x2F;www.effectiveengineer.com&#x2F;" rel="nofollow">http:&#x2F;&#x2F;www.effectiveengineer.com&#x2F;</a>
评论 #33856014 未加载
TruffleLabs超过 2 年前
The Mythical Man-Month: Essays on Software Engineering, Frederick P. Brooks * still relevant re: people are the key to getting things done; understand how people work together.<p><a href="https:&#x2F;&#x2F;www.abebooks.com&#x2F;products&#x2F;isbn&#x2F;9780201006506" rel="nofollow">https:&#x2F;&#x2F;www.abebooks.com&#x2F;products&#x2F;isbn&#x2F;9780201006506</a>
评论 #33860122 未加载
评论 #33856354 未加载
评论 #33925435 未加载
rubicon33超过 2 年前
Recommend this book, but honestly you don&#x27;t need to read it:<p>Deep Work: Cal Newport<p>What you need to know from this book is that to write good software (both quality and quantity) you need to go deep. You need to fully absorb and understand the problem in your mind, BEFORE you begin writing code. And then, you need quiet undistracted time to map the thoughts in your mind, to code on paper.<p>This process of turning a mental model in your mind, into a well designed code model, takes more focus than you think (if you want to do it well). Give yourself a quiet room with no visual distractions. Just you, and your code. Set aside a few hours.<p>Most importantly of all - Remove the possibility in your mind, that a distraction could happen. I cannot emphasize this enough. Your mind will not go deep if, even on a subconscious level, you think a distraction could come. A text message, a spouse walking in, a co-worker asking a question, etc. These all need to be (as reasonably as possible) NOT possible so that your mind can go quiet, and you can take on the work.
评论 #33857225 未加载
pjmorris超过 2 年前
&#x27;Becoming A Technical Leader&#x27;, Gerald Weinberg. Jerry, working for IBM, designed the telemetry system NASA used to track early manned space flights and then spent a career helping organizations, teams, and people achieve their goals, both technical and personal. He wrote many books on the topics you mention, all of them worthwhile. I picked this one as a place to start.<p>&#x27;Making Things Happen&#x27;, Scott Berkun. Berkun was a successful developer and product manager at Microsoft and the book captures his reflections and research on project management.
hardwaregeek超过 2 年前
I’m currently reading Peopleware which is simultaneously very insightful and very obvious. It’s also a bit of a marker in time of how software development worked. I’d say a lot has improved with remote work, at least for some companies.<p>I found The Mom Test pretty helpful for honing a product mindset. I’ve fallen into the trap of writing code simply because I find it less daunting than talking to users. The Mom Test is a good reminder on priorities.
评论 #33858314 未加载
评论 #33857223 未加载
rahimnathwani超过 2 年前
Staff Engineer: Leadership beyond the management track by Will Larson (<a href="https:&#x2F;&#x2F;staffeng.com&#x2F;book" rel="nofollow">https:&#x2F;&#x2F;staffeng.com&#x2F;book</a>)<p>Peopleware
评论 #33855843 未加载
pkoird超过 2 年前
So I asked this same question to ChatGPT, here&#x27;s its response. This thing really does have the potential to be a good recommendation tool for books&#x2F;resources.<p>&quot;Here are a few books that may be helpful for improving your skills as a software engineer:<p>&quot;The Pragmatic Programmer&quot; by Andrew Hunt and David Thomas: This book offers practical advice on a wide range of topics, including how to write clean and maintainable code, how to work effectively with others, and how to manage your time and priorities.<p>&quot;Clean Code&quot; by Robert C. Martin: This book focuses on the importance of writing code that is easy to read and understand, and provides specific guidance on how to write clean and maintainable code.<p>&quot;Peopleware&quot; by Tom DeMarco and Timothy Lister: This book discusses the human side of software development, including how to create effective teams and work environments, and how to avoid common pitfalls such as overwork and burnout.<p>&quot;Agile Software Development&quot; by Alistair Cockburn: This book provides an introduction to agile software development methodologies, which are designed to help teams deliver high-quality software quickly and efficiently.<p>In addition to these books, there are many excellent blog posts and online resources on these topics. Some websites that may be helpful include the Pragmatic Programmer blog, the Agile Alliance website, and the ACM SIGSOFT Software Engineering Notes journal.<p>Another helpful resource may be attending conferences and workshops on software engineering and related topics. These can provide opportunities to learn from experts in the field, network with other professionals, and stay up to date on the latest trends and best practices. Many conferences and workshops also offer certification programs, which can be a valuable way to demonstrate your knowledge and expertise to potential employers. Some well-known conferences in the software engineering field include the ACM SIGSOFT International Symposium on the Foundations of Software Engineering (FSE), the ACM SIGCHI Conference on Human-Computer Interaction (CHI), and the International Conference on Software Engineering (ICSE). &quot;
评论 #33861218 未加载
评论 #33857642 未加载
评论 #33858747 未加载
评论 #33898686 未加载
loloquwowndueo超过 2 年前
I got a ton of value out of “Peopleware: Productive Projects and Teams”. Even if you’re not a manager that can directly follow the advice, as an engineer it will provide great clues on how to ensure environment and team dynamics can greatly influence efficiency and chances of success.<p>Of course my all time favorite is The Mythical Man-Month. But that’s already mentioned elsewhere in this thread.<p>I haven’t read “Drive: The Surprising Truth About What Motivates Us” but some of the concepts it talks about are also of interest (on how to ensure workers are motivated and I’m not talking about “the beatings will continue until morale improves” :) )
summertime42超过 2 年前
I have all of these on my shelf. Fantastic reads.<p>* Extreme Programming Explained by Kent Beck<p>* Clean Code and The Clean Coder by Robert C. Martin<p>* Soft Skills by John Sonmez (1st edition)<p>* Pragmatic Programmer by Andrew Hunt and David Thomas<p>* Working Effectively with Legacy Code by Michael Feathers<p>* The Mythical Man-Month by Frederick Brooks<p>(Selfish plug) Additionally, I wrote my own book concerning the entire industry, from just starting out to becoming a self employed consultant when you get sick of fulltime work - all soft skills from my decade or so of the industry, as well - <a href="https:&#x2F;&#x2F;www.amazon.com&#x2F;dp&#x2F;B0B43V1JJW" rel="nofollow">https:&#x2F;&#x2F;www.amazon.com&#x2F;dp&#x2F;B0B43V1JJW</a>
评论 #33856977 未加载
评论 #33857898 未加载
cauthon超过 2 年前
A Philosophy of Software Design by John Ousterhout is good reading
评论 #33858068 未加载
ArcMex超过 2 年前
I’m always looking to improve my set of skills, so thank you for the thread and thank you for the responses- I have managed to pick up some recommendations.<p>My personal recommendation would be Deep Work by Cal Newport as it is my most recent read, having completed it just the day before yesterday.<p>I applied what I learned and discovered that I was able to meet deadlines much easier than before. I’m also in the process of applying deep focus techniques to my work weeks to ensure I have a tangible build or product every Friday. Could be a document, a repo, a feature, etc. So far so good. This past week I delivered a Design Spec document in record time.<p>Thanks again and take care.
mikehollinger超过 2 年前
“The Effective Manager” by the people behind Manager Tools (a great podcast) is a really, really good view of this.<p>Re: Communication, this book starts there and builds upon that foundation. It’s targeted at line managers, but anyone in a leadership position can and will benefit. For example, I don’t do one-on-one’s with my team. I do “Project Management 1:1’s” or “Weekly project status updates.” I don’t always give feedback the way they prescribe (because the team doesn’t formally report to me). I do, however, go out of my way to say “Just to let you know, when you do X, Y happens.” And from the book, learned that there’s a 10:1 ratio of positive to negative feedback to strive for.<p>Side note: Manager Tools has a great podcast series that is arranged into a “map of the universe” [1] which shows a huge list of topics, and how to discuss everything from good or bad performance, dealing with various types of conflict, to even how to structure emails or how to address a personal scent issue (which I’ve actually used).<p>[1] <a href="https:&#x2F;&#x2F;www.manager-tools.com&#x2F;map-of-the-universe" rel="nofollow">https:&#x2F;&#x2F;www.manager-tools.com&#x2F;map-of-the-universe</a>
评论 #33855805 未加载
jpgvm超过 2 年前
People have recommended some excellent books.<p>I will advise something different, find a mentor.<p>The most important parts of actually -engineering- software, not bashing out code come from intuition and taste and these are best taught through a mentor.<p>If you can&#x27;t find a mentor at your current company then consider getting involved in OSS, particularly in well engineered projects like Linux, PostgreSQL, Apache projects, etc. If you have the capacity for this it&#x27;s one of the strongest ways to increase your capability and strengthen&#x2F;widen your network which will help further your career in other ways.<p>Once you have found a mentor focus on being a good student. Learn how to ask the questions that will prompt insightful answers, the &quot;why&quot; rather than the &quot;how&quot;. Especially try to learn what -not- to do. Experience doesn&#x27;t always need to come first hand... getting burnt isn&#x27;t necessary to understand not to touch hot stuff.<p>Not the answer you asked for but I think perhaps even more important than what you can learn from a book.
ldjkfkdsjnv超过 2 年前
My personal opinion is reading about coding does nothing. Its like reading about math without doing the exercises. You need to work on good codebases, and have your code reviewed by people who are good.
评论 #33856562 未加载
评论 #33856602 未加载
评论 #33860302 未加载
评论 #33856894 未加载
评论 #33856540 未加载
评论 #33860271 未加载
评论 #33860975 未加载
评论 #33885960 未加载
allenleein超过 2 年前
SICP (Structure and Interpretation of Computer Programs)<p><a href="https:&#x2F;&#x2F;web.mit.edu&#x2F;6.001&#x2F;6.037&#x2F;sicp.pdf" rel="nofollow">https:&#x2F;&#x2F;web.mit.edu&#x2F;6.001&#x2F;6.037&#x2F;sicp.pdf</a>
pieterr超过 2 年前
Camille Fournier - The Manager&#x27;s Path<p><a href="https:&#x2F;&#x2F;www.amazon.com&#x2F;Managers-Path-Leaders-Navigating-Growth&#x2F;dp&#x2F;1491973897&#x2F;" rel="nofollow">https:&#x2F;&#x2F;www.amazon.com&#x2F;Managers-Path-Leaders-Navigating-Grow...</a><p><a href="https:&#x2F;&#x2F;www.elidedbranches.com&#x2F;" rel="nofollow">https:&#x2F;&#x2F;www.elidedbranches.com&#x2F;</a>
评论 #33859829 未加载
leetrout超过 2 年前
A Philosophy of Software Design<p><a href="https:&#x2F;&#x2F;web.stanford.edu&#x2F;~ouster&#x2F;cgi-bin&#x2F;book.php" rel="nofollow">https:&#x2F;&#x2F;web.stanford.edu&#x2F;~ouster&#x2F;cgi-bin&#x2F;book.php</a><p>Righting Software<p><a href="https:&#x2F;&#x2F;rightingsoftware.org&#x2F;" rel="nofollow">https:&#x2F;&#x2F;rightingsoftware.org&#x2F;</a>
squeegee_scream超过 2 年前
Will Larson’s An Elegant Puzzle <a href="https:&#x2F;&#x2F;lethain.com&#x2F;elegant-puzzle&#x2F;" rel="nofollow">https:&#x2F;&#x2F;lethain.com&#x2F;elegant-puzzle&#x2F;</a>. It is mostly or entirely taken from his blog so you can just read the blog for free but I find the book valuable
dxs超过 2 年前
You can take a look at the following. Doesn&#x27;t look like anyone else has mentioned this yet.<p>As with everything else, check it out, adopt what looks good, adapt it to your needs.<p>&gt; Watts Humphrey: <a href="https:&#x2F;&#x2F;en.wikipedia.org&#x2F;wiki&#x2F;Watts_Humphrey" rel="nofollow">https:&#x2F;&#x2F;en.wikipedia.org&#x2F;wiki&#x2F;Watts_Humphrey</a><p>&gt; Personal software process: <a href="https:&#x2F;&#x2F;en.wikipedia.org&#x2F;wiki&#x2F;Personal_software_process" rel="nofollow">https:&#x2F;&#x2F;en.wikipedia.org&#x2F;wiki&#x2F;Personal_software_process</a><p>&gt; Team software process: <a href="https:&#x2F;&#x2F;en.wikipedia.org&#x2F;wiki&#x2F;Team_software_process" rel="nofollow">https:&#x2F;&#x2F;en.wikipedia.org&#x2F;wiki&#x2F;Team_software_process</a><p>&gt; More at Libgen: <a href="http:&#x2F;&#x2F;libgen.rs&#x2F;search.php?req=watts+humphrey&amp;lg_topic=libgen&amp;open=0&amp;view=simple&amp;res=25&amp;phrase=1&amp;column=def" rel="nofollow">http:&#x2F;&#x2F;libgen.rs&#x2F;search.php?req=watts+humphrey&amp;lg_topic=libg...</a><p>&gt; More at PDF Drive: <a href="https:&#x2F;&#x2F;www.pdfdrive.com&#x2F;search?q=watts+humphrey&amp;pagecount=&amp;pubyear=&amp;searchin=&amp;em=1" rel="nofollow">https:&#x2F;&#x2F;www.pdfdrive.com&#x2F;search?q=watts+humphrey&amp;pagecount=&amp;...</a>
antipaul超过 2 年前
The Missing Readme” book seems right up your alley<p><a href="https:&#x2F;&#x2F;nostarch.com&#x2F;missing-readme" rel="nofollow">https:&#x2F;&#x2F;nostarch.com&#x2F;missing-readme</a><p>“The Missing README fills in that gap—a distillation of workplace lessons, best practices, and engineering fundamentals that the authors have taught rookie developers at top companies for more than a decade”<p>Get it just for the “Design Doc” template!
评论 #33857288 未加载
bwb超过 2 年前
Michael Levine shared the best books about leading great software teams, this might be right up your alley: <a href="https:&#x2F;&#x2F;shepherd.com&#x2F;best-books&#x2F;if-you-want-to-lead-great-software-delivery-teams" rel="nofollow">https:&#x2F;&#x2F;shepherd.com&#x2F;best-books&#x2F;if-you-want-to-lead-great-so...</a><p>And, John Sonmez wrote about great books for software developers on the soft skill size - <a href="https:&#x2F;&#x2F;shepherd.com&#x2F;best-books&#x2F;fun-for-software-developers" rel="nofollow">https:&#x2F;&#x2F;shepherd.com&#x2F;best-books&#x2F;fun-for-software-developers</a>
bilsbie超过 2 年前
Anyone know if the old Joel on software essays are still around? Are they still relevant?
评论 #33858350 未加载
ayewo超过 2 年前
Mythical Man Month by Fred Brooks is pretty good. There is also the Design of Everyday Things (TDoET) by Don Norman.<p>Structured Design from 1975 by Larry L. Constantine and Ed Yourdon is another excellent book that I am currently reading now.
Multicomp超过 2 年前
&gt; converting asks to deliverables, managing expectations from management, enabling team members by opening communication channels across teams, time management<p>These all sound like David Allen&#x27;s Getting Things Done, the art of stress free productivity.<p>&gt; converting asks to deliverables<p>GTD teaches you to ask what the correct outcome is and what the next action item to get there is (and what those questions even mean) so your projects are always moving forward<p>&gt; managing expectations from management<p>GTD talks about setting up project lists so you are current and keeping you current when you meet with management<p>&gt;enabling team members by opening communication channels across teams<p>GTD teaches you how to brainstorm with the group and how to ensure everyone in a meeting knows what the next step to move the project forward is<p>&gt;time management<p>GTD teaches you someodels to help you best know what your time landscape is and give you reminders of what tasks need to be when and where if known otherwise it has a model of helping set priorities based on contexts available to you
jshen超过 2 年前
Become a better story teller and persuader, and learn how to make better decisions and manage risk. A few books that helped me in no particular order …<p>The Science of Storytelling - Will Storr<p>Influence - Robert Cialdini<p>Thinking Fast and Slow - Daniel Kahneman<p>Antifragile - Nassim Taleb<p>How Innovation Works - Natt Ridley<p>The One Thing You Need to Know - Marcus Buckingham<p>Team of Teams - General Stanley McChrystal
ilaksh超过 2 年前
My suggestion is that besides reading books, you could try to build a startup. It could just be consulting on your own (or with ChatGPT or Fiverr&#x2F;freelancing sites as your team). Then you will gain direct experience in a lot of those things.<p>Also here are a few ideas for managing scope, deliverables, expectations, time management. Structure things financially so that they are tied to relatively short iterations that require direct interaction with working software and between the engineers and the users and management at regular intervals. The communication with users AND management, payment, and deployment of working software at regular intervals should be strictly enforced. The project should not continue into the next iteration until all of those requirements are met for the current one.
评论 #33857097 未加载
评论 #33858369 未加载
la_fayette超过 2 年前
Elicitating the real needs of customers is the most challenging part for me within a software development process. The concept of Domain Driven Design (book by Eric Evan) helped me a lot to decode the language of the customer and transform it into an object model.
chiefalchemist超过 2 年前
&quot;You&#x27;re Not Listening&quot; by Kate Murphy.<p>It&#x27;s not at all software related but it will make you a better teammate, partner (i.e., client relationship), manager and&#x2F;or leader.<p>Technology is the easy part. People, that&#x27;s the difference between average and above.
评论 #33857300 未加载
mystickphoenix超过 2 年前
A few things come to mind along with what&#x27;s already been mentioned:<p>Assorted Non-Book Readings:<p>- <a href="https:&#x2F;&#x2F;randsinrepose.com&#x2F;dont-skip-this&#x2F;" rel="nofollow">https:&#x2F;&#x2F;randsinrepose.com&#x2F;dont-skip-this&#x2F;</a><p>- <a href="http:&#x2F;&#x2F;www.stilldrinking.org&#x2F;programming-sucks" rel="nofollow">http:&#x2F;&#x2F;www.stilldrinking.org&#x2F;programming-sucks</a><p>- <a href="https:&#x2F;&#x2F;sysadvent.blogspot.com&#x2F;2019&#x2F;12&#x2F;day-21-being-kind-to-3am-you.html" rel="nofollow">https:&#x2F;&#x2F;sysadvent.blogspot.com&#x2F;2019&#x2F;12&#x2F;day-21-being-kind-to-...</a><p>- <a href="https:&#x2F;&#x2F;donellameadows.org&#x2F;archives&#x2F;leverage-points-places-to-intervene-in-a-system&#x2F;" rel="nofollow">https:&#x2F;&#x2F;donellameadows.org&#x2F;archives&#x2F;leverage-points-places-t...</a><p>- <a href="https:&#x2F;&#x2F;grugbrain.dev&#x2F;" rel="nofollow">https:&#x2F;&#x2F;grugbrain.dev&#x2F;</a><p>- <a href="https:&#x2F;&#x2F;changelog.com&#x2F;posts&#x2F;rich-hickeys-greatest-hits" rel="nofollow">https:&#x2F;&#x2F;changelog.com&#x2F;posts&#x2F;rich-hickeys-greatest-hits</a><p>- <a href="https:&#x2F;&#x2F;github.com&#x2F;papers-we-love&#x2F;papers-we-love&#x2F;blob&#x2F;master&#x2F;design&#x2F;out-of-the-tar-pit.pdf" rel="nofollow">https:&#x2F;&#x2F;github.com&#x2F;papers-we-love&#x2F;papers-we-love&#x2F;blob&#x2F;master...</a><p>- <a href="http:&#x2F;&#x2F;www.cs.unc.edu&#x2F;techreports&#x2F;86-020.pdf" rel="nofollow">http:&#x2F;&#x2F;www.cs.unc.edu&#x2F;techreports&#x2F;86-020.pdf</a><p>Books:<p>- The Phoenix Project: Gene Kim, Kevin Behr, George Spafford<p>- Deep Work: Cal Newport<p>- The Art of Leadership: Michael Lopp (Rands)<p>- Extreme Ownership: Jocko Willink and Leif Babin (once you get through the ho-rah stuff it&#x27;s a fantastic read)<p>- Time Management for System Administrators: O&#x27;Reilly (fantastic for interrupt driven work)<p>- Elements of Clojure: Zachary Tellman (not just for Clojure devs)
评论 #33856117 未加载
jm1271超过 2 年前
Software Estimation: Demystifying the dark art is an under-appreciated book in this area.
评论 #33858408 未加载
评论 #33856060 未加载
vl超过 2 年前
<i>Peopleware</i> and <i>Mythical Man-Month</i> are fundamental to understanding larger software projects and teams.<p>They often state obvious things, but I didn’t guess them myself.<p><i>Mythical Man-Month</i> also provides important historical perspective.
foobazgt超过 2 年前
OP, I&#x27;ve been thinking about starting a column on those kinds of lines - generalized engineering advice. I have 20+ years of experience in the industry and have held both principal engineer and engineering director positions at S&amp;P 500s. Does that hold your interest?<p>For everyone else, I think I&#x27;ve created an interesting backlog of topics, but I&#x27;d love any advice about additional topics that would interest folks, how to kickstart an initial audience, what platform to use, how to moderate without losing my mind, and anything else that&#x27;d be useful to know doing this kind of thing.
评论 #33858259 未加载
评论 #33862039 未加载
评论 #33857157 未加载
merolish超过 2 年前
This list was posted a few months ago: <a href="https:&#x2F;&#x2F;news.ycombinator.com&#x2F;item?id=32305997" rel="nofollow">https:&#x2F;&#x2F;news.ycombinator.com&#x2F;item?id=32305997</a>
vasco超过 2 年前
I know you asked for books or blog posts, but I believe the best way is to read lots of code from the tools you use. Look into how your favorite libraries do things, for a start.
评论 #33858399 未加载
Solvitieg超过 2 年前
I noticed nobody had mentioned any Youtubers. Surprisingly there are a few Youtubers who bring a ton of industry experience to their videos.<p>I found these channels to be helpful:<p>- Rahul Pandey (e.g <a href="https:&#x2F;&#x2F;www.youtube.com&#x2F;watch?v=ADWkkJtZna4" rel="nofollow">https:&#x2F;&#x2F;www.youtube.com&#x2F;watch?v=ADWkkJtZna4</a>)<p>- A life engineered (e.g <a href="https:&#x2F;&#x2F;www.youtube.com&#x2F;watch?v=4i5iFlP01mQ" rel="nofollow">https:&#x2F;&#x2F;www.youtube.com&#x2F;watch?v=4i5iFlP01mQ</a>)
评论 #33859574 未加载
medler超过 2 年前
The Unwritten Laws of Engineering by WJ King is a great book on the people-skills side of engineering and management. At ~60 pages it’s also mercifully short and to the point.
soheil超过 2 年前
There are many books, articles, and other resources that can help you to become a better software engineer. Some popular choices include &quot;Clean Code&quot; by Robert C. Martin, &quot;The Pragmatic Programmer&quot; by Andrew Hunt and David Thomas, and &quot;Code Complete&quot; by Steve McConnell. These books provide practical advice and guidance on a range of topics, including design, testing, debugging, and refactoring.
评论 #33861877 未加载
ljf超过 2 年前
I loved &#x27;Joel on Software&#x27; - I got a heap from it (I was a PO but attempted to be as technically aware as possible).<p>Taught me so much about all the things you mentioned
turtledragonfly超过 2 年前
This is more on the &quot;managing lots of code&quot; rather than the people side of things, but: John Lakos has a book called &quot;Large-scale C++, volume I: Process and Architecture.&quot;<p>Even if you don&#x27;t read the book, I think this talk he gave on it is a good watch: <a href="https:&#x2F;&#x2F;www.youtube.com&#x2F;watch?v=4NvRnkz6jVM" rel="nofollow">https:&#x2F;&#x2F;www.youtube.com&#x2F;watch?v=4NvRnkz6jVM</a>
Noe2097超过 2 年前
Try &quot;Extreme Ownership&quot;.<p>It will give you concrete examples on how to broaden your scope out of just your individual contribution, by learning to care for all the rest, and pushing you to realize that to a large extent, the things you see as broken you can actually fix.<p>Even when they are not inside the codebase you are in charge of. Even if they aren&#x27;t even on engineering side.
jdougan超过 2 年前
&quot;Death March&quot;, by Ed Yourdon. Most of the reccommended books In this thread are about trying to keep a project in a good place. This book is about what to do when it has already gone wrong. You can make a not terrible argument that much of the industry has gone to an all-death-march-all-the-time model. This book can help.
zb超过 2 年前
I’m currently reading <i>The Staff Engineer&#x27;s Path</i> by Tanya Reilly and it’s really good (so far). It’s a great thing to read at the point it sounds like you have reached, where programming a little better is no longer going to move the needle, even if you aren’t in a position to apply everything in it yet.
rglover超过 2 年前
Systemantics is a fun read: <a href="https:&#x2F;&#x2F;www.amazon.com&#x2F;SYSTEMANTICS-SYSTEMS-BIBLE-John-Gall-ebook&#x2F;dp&#x2F;B00AK1BIDM" rel="nofollow">https:&#x2F;&#x2F;www.amazon.com&#x2F;SYSTEMANTICS-SYSTEMS-BIBLE-John-Gall-...</a>
pkdpic超过 2 年前
&gt; Weaving the Web by Tim BL<p>&gt; Of Ants and Dinosaurs by Liu Cixin<p>&gt; The Unix O&#x27;Reilly Guide<p>All quick entertaining reads. All written by software engineers. All utterly useless for managing state in your React apps.
brnstz超过 2 年前
Worse is Better: <a href="https:&#x2F;&#x2F;www.dreamsongs.com&#x2F;RiseOfWorseIsBetter.html" rel="nofollow">https:&#x2F;&#x2F;www.dreamsongs.com&#x2F;RiseOfWorseIsBetter.html</a>
smcleod超过 2 年前
An absolute must from a &quot;how to think&quot; and cultural perspective is The Phoenix Project, many years on I still think back to this frequently.
mooreds超过 2 年前
Hiya,<p>I&#x27;d consider these books&#x2F;articles&#x2F;podcasts:<p>* Secrets of Consulting by Gerald Weinberg: <a href="http:&#x2F;&#x2F;geraldmweinberg.com&#x2F;Site&#x2F;Consulting_Secrets.html" rel="nofollow">http:&#x2F;&#x2F;geraldmweinberg.com&#x2F;Site&#x2F;Consulting_Secrets.html</a> Every problem is a people problem.<p>* Refactoring by Martin Fowler et. al: <a href="https:&#x2F;&#x2F;martinfowler.com&#x2F;books&#x2F;refactoring.html" rel="nofollow">https:&#x2F;&#x2F;martinfowler.com&#x2F;books&#x2F;refactoring.html</a> talks about how and why to refactor, as well as providing a nomenclature for the process.<p>* Code Complete by Steve McConnell. <a href="https:&#x2F;&#x2F;stevemcconnell.com&#x2F;books&#x2F;" rel="nofollow">https:&#x2F;&#x2F;stevemcconnell.com&#x2F;books&#x2F;</a> A bit dated (the last version I could find was from 2004) but a great overview of the entire software process, from requirements to maintenance.<p>* The Mythical Man-Month by Fred Brookes: <a href="https:&#x2F;&#x2F;www.oreilly.com&#x2F;library&#x2F;view&#x2F;mythical-man-month-the&#x2F;0201835959&#x2F;" rel="nofollow">https:&#x2F;&#x2F;www.oreilly.com&#x2F;library&#x2F;view&#x2F;mythical-man-month-the&#x2F;...</a> best practices about software development, written about a project from the 1960 and 1970s.<p>* The Joel On Software Strategy Letters: <a href="https:&#x2F;&#x2F;www.joelonsoftware.com&#x2F;2000&#x2F;05&#x2F;12&#x2F;strategy-letter-i-ben-and-jerrys-vs-amazon&#x2F;" rel="nofollow">https:&#x2F;&#x2F;www.joelonsoftware.com&#x2F;2000&#x2F;05&#x2F;12&#x2F;strategy-letter-i-...</a> is the first one. All of them (I think there are five) are great.<p>* Letters to a New Developer: <a href="https:&#x2F;&#x2F;letterstoanewdeveloper.com&#x2F;the-book&#x2F;" rel="nofollow">https:&#x2F;&#x2F;letterstoanewdeveloper.com&#x2F;the-book&#x2F;</a> Please note I wrote this, but I still think it does a good job of discussing the &quot;soft skills&quot; in an easily digestible format.<p>* Pragmatic Programmer by Dave Thomas and Andy Hunt: <a href="https:&#x2F;&#x2F;pragprog.com&#x2F;titles&#x2F;tpp20&#x2F;the-pragmatic-programmer-20th-anniversary-edition&#x2F;" rel="nofollow">https:&#x2F;&#x2F;pragprog.com&#x2F;titles&#x2F;tpp20&#x2F;the-pragmatic-programmer-2...</a> Haven&#x27;t read the revised 20th anniversary edition, but the first one opened my eyes to the craft of software.<p>* High Output Management by Andy Grove: <a href="https:&#x2F;&#x2F;bookshop.org&#x2F;p&#x2F;books&#x2F;high-output-management-andrew-s-grove&#x2F;6730629" rel="nofollow">https:&#x2F;&#x2F;bookshop.org&#x2F;p&#x2F;books&#x2F;high-output-management-andrew-s...</a> a great way to think about throughput<p>* The Phoenix Project by Gene Kim et. al: <a href="https:&#x2F;&#x2F;itrevolution.com&#x2F;product&#x2F;the-phoenix-project&#x2F;" rel="nofollow">https:&#x2F;&#x2F;itrevolution.com&#x2F;product&#x2F;the-phoenix-project&#x2F;</a> Fun novel(!) about applying lean management principles to software engineering.<p>* Radical Candor (haven&#x27;t read, but it&#x27;s been recommended): <a href="https:&#x2F;&#x2F;www.radicalcandor.com&#x2F;" rel="nofollow">https:&#x2F;&#x2F;www.radicalcandor.com&#x2F;</a> About communication.<p>* Good to Great by Jim Collins: <a href="https:&#x2F;&#x2F;en.wikipedia.org&#x2F;wiki&#x2F;Good_to_Great" rel="nofollow">https:&#x2F;&#x2F;en.wikipedia.org&#x2F;wiki&#x2F;Good_to_Great</a> Focuses on what great companies bring to the table. Helps me evaluate where to work.<p>* Mastery Autonomy and Purpose: A great video about what people really want in work: <a href="https:&#x2F;&#x2F;www.youtube.com&#x2F;watch?v=MzXXC4MZZnY" rel="nofollow">https:&#x2F;&#x2F;www.youtube.com&#x2F;watch?v=MzXXC4MZZnY</a><p>* <a href="https:&#x2F;&#x2F;www.manager-tools.com&#x2F;podcasts" rel="nofollow">https:&#x2F;&#x2F;www.manager-tools.com&#x2F;podcasts</a> a podcast about managing people. You didn&#x27;t say you wanted to be a people manager, but knowing what managers think about will make you more effective in any org.<p>* Managing Humans by Michael Lopp: <a href="https:&#x2F;&#x2F;managinghumans.com&#x2F;" rel="nofollow">https:&#x2F;&#x2F;managinghumans.com&#x2F;</a> The whole Rands site is work reading, but I enjoyed this book about how to manage teams and build software. See above.<p>* Don&#x27;t Make Me Think by Steve Krug: <a href="https:&#x2F;&#x2F;sensible.com&#x2F;dont-make-me-think&#x2F;" rel="nofollow">https:&#x2F;&#x2F;sensible.com&#x2F;dont-make-me-think&#x2F;</a> Easy ways to think about usability, focusing on webapps. Short and easy.<p>* Badass: Making Users Awesome, by Kathy Sierra: <a href="http:&#x2F;&#x2F;seriouspony.com&#x2F;badass-users-the-book" rel="nofollow">http:&#x2F;&#x2F;seriouspony.com&#x2F;badass-users-the-book</a> Will help you put yourself in the shoes of your users and think about how to build software they will love. Short and easy.<p>Hope this helps.
jll29超过 2 年前
&gt; Ask HN: Reading material on how to be a better software engineer?<p>That&#x27;s a bit like &quot;Ask HN: Reading material on how to be a better pianist?&quot;<p>You will need to write and maintain a lot of code, and make a lot of mistakes, then you will get gradually better.
supr_strudl超过 2 年前
The Pragmatic Programmer (Hunt)<p>Refactoring (Folwer)
dunk010超过 2 年前
The Design of Design.
boredemployee超过 2 年前
forget it... AI gonna replace all of us