点击上方“大鱼机器人”,选择置顶或星标公众号

福利干货,第一时间送达!

作者 | Gergely Orosz

译者 | 王强

策划 | 小智

回顾十年之前,有一些事情,我希望当初刚入行当程序员的我就能明白,并尽早养成这些习惯。它们可以帮助我更快、更专注地成长。以下是我的一些建议,给当年刚找到第一份程序员工作的我。

1每年花时间读两本关于软件工程的书

我每次花时间缓慢而认真地阅读别人推荐的软件工程书籍时,自身都会得到提升。所谓认真阅读,我的意思是要做笔记、与他人交谈、写写画画、动手尝试、回过头来重新阅读。

我希望我在成为开发人员的头几年就阅读与软件相关的书籍。 但我是在从业第 5 年左右才开始这样做的。诸如《C#深入》,《简洁代码》和《Javascript:The Good Parts》之类的书都帮助我提升了技术水平。我并不是在推荐具体的书名——不管怎么说,其中有些都已经过时了。我的建议是寻找比你现有知识更深入的书籍,可以是关于特定技术或关于软件工程实践的著作。

看这些书时我不会一目十行。实际上,我看得很慢。我通常每次坐下来只读一两章。看的时候,我会做笔记或把重点划出来;看完后,我会回顾并经常与他人讨论。我也开始写一些书评放在自己的个人博客:

https://blog.pragmaticengineer.com/my-reading-list/

主要是反思我学到的东西。过去几年,我养成了这些习惯。这些习惯帮助我以技术经理的身份迅速成长:它们对工程师来说也非常有益。想找推荐书单吗?这里是我已经看过的和正在看的 书籍清单。

为什么书籍要好过博文、视频或演讲?其实我认为书籍比其他加起来都要好。无论什么样的主题内容,与书籍相比,其他的格式都会流于表面。书籍里的知识更深入,而且组织良好。像本文这样的帖子,我只需要花费几个小时来写,但是我花费在 我写的这本关于软件工程师成长的书籍上 已经将近一年。我认为读书可以更缓慢但深入地消化知识。

不要太贪心:每六个月读完一本书已经很棒了。挑选一本好书,多花一些时间好好阅读。在读了一两本书之后,我还建议你阅读《如何读一本书:智能阅读的经典指南》一书,强烈推荐。

2精研你工作中主打的编程语言,学到底层

我刚开始时主要用 PHP,兼写一点初级 JavaScript。我在大学里学过 C 和 C ++,都不喜欢。我的第一份全职工作用的是 C#。我了解很多种语言,但是没有一种语言学得非常好。

两年后,我开始遇到一些麻烦,在调试 C#代码时不得不找高级开发人员帮忙。其中一个总是帮我调试程序的高级工程师,他似乎非常了解这种语言,他向我推荐了一本书《C#深度学习》让我去看。然后我看了。我一路学到线程、垃圾回收和泛型的工作方式,这些都是底层知识。我花了数不清的时间去了解协方差(covariance)、逆方差(contravariance)和其他艰深的主题。

精研我工作中主打的语言是我做出的最佳决定之一。 在我的第一份工作中,这种研究只是无意为之的,并且还得靠那位高级工程师指点;但是,这些知识在工作中,以及面试其他工作时都成了一种优势。在我职业生涯的后期,我有意深入研究新的语言和框架。我是作为 C # 程序员加入 Skype 的,但是,我们需要改用 JavaScript 和 WinJS。因此,我又深入学习了 JS,并掌握了 WinJS,以至于我可以 在 Pluralsight 上开课。

你懂的语言越多,就越了解它们各自的长处和短处。 当我转移到 iOS 时,我已经精通好几种语言。Swift 出现时,我简单关注并参与了语言讨论,并 建议添加读写反射这项能力 到 swift 的未来规划中。了解了该语言的特性后,就可以更容易地找出让我的团队 从 Objective-C 迁移到 Swift 的最佳策略。而且,你知道的语言越多,就越容易掌握新的语言——并且在需要时更轻松地深入学习。

3多与他人结对编程

我觉得最近结对编程已经过时了。当年我们开始时,长期结对的极限编程、测试驱动开发和 mob 编程都很受欢迎。与人结对之后,我获得了职业生涯中一些最大的跃升。这些跃升比读书更重要。

我曾与一位开发人员有过一次难忘的结对编程经历。他对包括我在内的所有人都进行了严格的代码审查。有一天我受够了代码审查工具上的评论,决定不再在上面答复,而是坐在这些评论者旁边,要求他们当面向我说明他们的评论。我最终学到了很多东西——同时还告诉他们,我认为他们的评论不公平。他们注意到了这点,建议我每当有这种情况时就结对编程。然后我就去做了。这位开发人员对性能有所了解,我通过跟他结对编程,了解到了潜在的性能瓶颈的来龙去脉——然后我教给他们有关可维护性方面的知识作为回报。

与另一位工程师进行测试驱动开发经历,是我在结对编程中的另一个美好回忆。我们轮流编写代码和测试代码。我们做了两天,实现了系统中一个棘手的部分。那次经历实在令我大开眼界。我们在验证所有边界值的过程中,甚至反过来完全改变了实现方法。我们还与该开发商建立了牢固的纽带并持续了数月之久。

4编写单元测试用例,并在持续集成中运行

高级工程师们经常谈论单元测试的重要性。但是单元测试似乎太违反直觉了:为什么要花更多的时间编写看起来很简单的测试?这是我在某段时间里对单元测试的看法。

为了领略单元测试的价值,你需要拥有“啊哈!”时刻——当你编写的单元测试为你节省了一天的时间,那就是“啊哈!”时刻。在到达这一步之前,你需要脚踏实地,好好编写这些测试,并使它们在持续集成中运行。而且,你可能需要持续做上几个月,才会得到一个“啊哈!”时刻。

我有两个这样的时刻。第一个发生在我为一个小型在线赌场构建后端引擎(作为辅助项目)时。该 API 正在管理真金白银,我因为害怕犯错误,所以用单元测试覆盖了所有代码。该项目交付比我预想要晚——部分原因归咎于测试,它们耗费了很多时间。但是这样做是正确的。我在合同结束时将项目移交给了客户,两年后,他们告诉我,这些测试多次挽救了团队——如果不是因为测试失败,代码漏洞将会扩散到生产环境中。

我的另一个“啊哈”时刻是在 Web 上构建 Skype。我们在 web.skype.com 上给 Google Hangouts 创造了一个新的竞争对手。我们团队是一支强大的团队,拥有完整的单元覆盖范围和严格的集成测试。进入项目三个月后,工程师决定重构整个项目的结构。这是非常冒险的重构,我们所有人都投票反对这样做。

那位工程师指出,基于现有的测试覆盖率,这次重构应该是小菜一碟,只要测试通过,重构就没问题。我对此表示怀疑。但这正是测试用例的用处。经过为期一周的重构,他推动了一次巨大的变革……一切都没有中断,当时没有,之后也没有。所有测试均通过。就在那刻,我意识到了一套强大的测试用例所能提供的安全保障,以及它能够让我们不害怕重构的事实。

5养成重构习惯并掌握重构工具

多年来,当我与团队合作时,我倾向于在代码库中进行尽可能小的更改。对于我自己的个人项目,我进行了大量的重构——但是我从来不在我不完全掌控的代码库上做这种事情。

然后,我在 Skype 遇到了一位工程师,他会不断进行小型或大型重构。他们都有道理,并且代码总是变得更好。而且他们从不搞乱事情。他们是如何做到的呢?

当我与他们结对编程时,发现他们非常了解自己的 IDE,并添加了用于重构的插件。提取方法、改变量名、提取成常量..……他们只需要花一秒钟。

我意识到,我害怕重构,既错过了实践,又错过了能帮助我重构的工具。 于是当我开始养成每周重构一次的习惯时,我在这两个方面都提升了。这个习惯后来对我很有帮助——我多么希望自己在很多年前就开始这么做啊。

6学习良好的软件工程经验,这使我获益良多

在我刚开始做软件工程师的时候,我曾经被高级工程师唬到了。他们看出了我没看出来的错误,他们知道我不知道的答案。我当时以为他们比我更聪明,并且接受了这一切。

现在,我已经与许多著名的软件工程师紧密合作过,并担任了另外几位的导师,我发现没有那么唬人。最好的软件工程师会把学到的知识和实际经验结合在一起——知识,你可以去学;经验,你需要去实践。

找机会在不同的技术栈、不同的领域和具有挑战性的项目里工作。 我花了七八年的时间才达到我认为的“高级”水平。我看到有些人加入了像 Uber 这种高成长性的公司,三四年就达到了。这中间的区别是什么?这些人从事具有挑战性的项目,力求跟上周围其他人的步伐,并经常在中途更换团队,重新开始。他们自愿参与新项目,并在团队中率先尝试新技术。虽然我最终还是成为了这样的人,但那是后来的事,不是在最初的几年中。

7把所学教给他人

学习某些东西,最好的方法是把它们教给别人。我是很偶然发现这一点的。在 2010 年,我开始在.NET 和 Windows Phone 用户组中 做演示。我的演讲效果不佳,但是我仅在准备阶段就学到了很多东西。

现在,当我想学好东西时,就会报名参加了一次公开讨论。 加入 Uber 一年后,我提出做一个演讲,介绍在 2017 年 Uber 如何大规模推出后端更改。当时,我还不完全了解我们是如何做到的——在那之前,我主要从事移动开发,并管理一个移动团队。通过演讲,我别无选择,只能学习所有细节。我这样做的压力很大:大约有 100 个本地开发人员报名要来听我的演讲。

许多其他人也说这种方法很有效——Shawn“Swyx” Wang 是 #LearnInPublic approach 的杰出代表。他的成长故事远比我的经历令人印象深刻:改行后在四年里做到 Netlify 和 AWS 的高级工程师职位,并 撰写了一本 关于他学习经历的书。教别人你只会得到好处。你不仅可以通过教学来学到东西,而且还可以帮助和启发他人。

而且我认识的所有经验丰富的模范开发人员,都是合格的老师和导师。越早开始回馈和教导,就会越自然而然地成为这样的开发人员。

延伸阅读

https://blog.pragmaticengineer.com/advice-to-myself-when-starting-as-a-software-developer/


-END-

整理文章为传播相关技术,版权归原作者所有 |

| 如有侵权,请联系删除 |

往期好文合集

硬核妹子的创意设计:舌头控制器

CPU为什么是方形而不是圆形的?

只有6个引脚的单片机,居然可以玩游戏。

最 后

若觉得文章不错,转发分享,也是我们继续更新的动力。

5T资源大放送!包括但不限于:C/C++,Linux,Python,Java,PHP,人工智能,PCB、FPGA、DSP、labview、单片机、等等

在公众号内回复「更多资源」,即可免费获取,期待你的关注~

一些建议:给当年刚做程序员的我相关推荐

  1. 极客新闻——17、给决定长久做程序员的你三个建议

    本文笔记全部来自<极客新闻>--新鲜的技术资讯.权威的趋势剖析.别样的技术洞察 本文作者结合StackOverflow发布的2019年的年度程序员调查显示,25-29岁的程序员占总人数的近 ...

  2. 阿里程序员吐槽:毕业4年,刚存够一百万不想再做程序员,想回老家生活

    近日,阿里某程序媛在某职场交流平台求助,其表示:刚存够 100 万,但是不想再做程序员了,单身29岁,想离开北京回老家过简单的生活. 话题一出,马上迎来了很多人的讨论,有很多热心网友纷纷给出自己的建议 ...

  3. “转行做程序员”很难?这里有4个建议

    近几年来,传统行业多处于经济下行,加上互联网行业的赚钱效应,想要转行到这一行的人越来越多,其中程序员这个行业更是很多人梦寐以求的. 但另一方面,我们也发现,这些想要转行的同学们往往会遇到很多困扰.就在 ...

  4. 刚毕业在深圳做程序员,我来聊聊月薪1万在大城市生活能剩下多少

    我今年刚毕业,然后在大城市做IT,可能工资大概1万左右.现在讨论一下,月薪1万在大城市最后能留下多少.以下是兴哥的一位刚毕业没多久的程序员朋友,给大家分享一下程序员的薪资水平,在大城市生活 ,一个月会 ...

  5. 在中国,也能一辈子做程序员?

    由于国内外软件发展起步不同,加上近年来关于程序员遭遇 35 岁职业危机和行业内卷的问题愈发凸显,在中国一辈子当程序员似乎是一件很困难的事情. 在金山办公副总裁以及 AI 中台负责人姚冬看来,关于能不能 ...

  6. 在中国,也能一辈子做程序员

    点击上方 "大数据肌肉猿"关注, 星标一起成长 后台回复[加群],进入高质量学习交流群 2021年大数据肌肉猿公众号奖励制度 作者|燕珊 采访嘉宾|姚冬 由于国内外软件发展起步不同 ...

  7. 听说做程序员年入百万,能不能带带你表弟?

    在脉脉上看到这样一份帖子:一位程序员的二姨听说程序员一年能挣100万,希望让程序员将自己的儿子弄到他们公司去. 二姨:阳阳,听说你们程序员一年能挣100万啊,能不能把你弟弟招过去? 程序员:???你听 ...

  8. 一入编码深似海,在达观数据做程序员是怎样一种体验?

    在技术浪潮一波接一波推动人类社会前进的历史进程当中,程序员始终是站在浪尖的群体.2014年起,把每年10月24日(2^10)定义为程序员节.这可能是唯一一个与数字紧密相关的节日--也体现了这个节日的含 ...

  9. 特别策划:非计算机专业如何转行做程序员?

    随着互联网的飞速发展,云计算.大数据由"热点"到落地,也带动着市场对软件开发者的需求,而目前国内软件开发从业者本已供不应求.互联网的火热不仅给软件开发者带来更为广阔的空间,就业薪资 ...

最新文章

  1. 详解Node.js包的工程目录与NPM包管理器的使用_node.js
  2. 云原生五大趋势预测,K8s 安卓化位列其一
  3. WebKit Frame对象分析
  4. Java程序中AB类可调用_19年【石油大学】《Java语言程序设计》二次在线作业(100分)...
  5. fir.im Weekly - 1000 个 Android 开源项目集合
  6. python logistics regression_Python——sklearn 中 Logistics Regression 的 coef_ 和 intercept_ 的具体意义...
  7. 第七节:语法总结(1)(自动属性、out参数、对象初始化器、var和dynamic等)
  8. Strus2第一次课:dom4j操作xml
  9. Mysql报错130_Mysql报错Forcing close of thread 139 user: 'root'
  10. LeetCode-76: 最小覆盖子串
  11. Structs 2 session 学习
  12. vfp 连接mysql数据库,vfp数据库的asp连接
  13. 技术人员的会议优化记录
  14. 参加神州英才执行力培训课程感悟
  15. Linux perf 事件调度算法
  16. 美国华盛顿州立大学计算机排名,2019上海软科世界一流学科排名计算机科学与工程专业排名华盛顿州立大学排名第301-400...
  17. work-stealing调度算法
  18. [译转]how browsers work
  19. SSH java 面试题
  20. python字符串前加字母u或者r区

热门文章

  1. 使用SAP云平台Portal service的前置条件
  2. SAP UI5 jQuery.sap.includeStyleSheet
  3. SAP UI5 global configuration interface
  4. ABAP开发者上云的时候到了 - 现在大家可以免费使用SAP云平台ABAP环境的试用版了
  5. SAP UI5 Component-preload.js
  6. SAP odata模型缓存校验机制
  7. windows10下的nc
  8. IBASE business knowledge from Gerhard
  9. SAP CRM Enterprise Search change pointer的存储数据库表
  10. php 去掉数组中的空值_PHP删除数组中空值的方法介绍