在完成上述的入门知识学习之后,我们要向专业的计算机软件开发进军了。但是在学习那些专业的知识前,我们先要抽一部分的篇幅来说一下程序员的修养。这是程序员的工程师文化,也就是程序员的价值观,因为我觉得如果你的技术修养不够的话,你学再多的知识也是没有用的。 要了解程序员的修养,你可以先从Quora上的这个贴子开始 “[What are some of the most basic things every programmer should know?](https://www.quora.com/What-are-some-of-the-most-basic-things-every-programmer-should-know)”,我摘录一些在这里供你参考。 - Bad architecture causes more problems than bad code. - You will spend more time thinking than coding. - The best programmers are always building things. - There’s always a better way. - Code reviews by your peers will make all of you better. - Fewer features for better code is always the right answer in the end. - If it’s not tested, it doesn’t work. - Don’t reinvent the wheel, library code is there to help. - Code that’s hard to understand is hard to maintain. - Code that’s hard to maintain is next to useless. - Always know how your business makes money, that determines who gets paid what. - If you want to feel important as a software developer, work at a tech company. 然后是 《[97 Things Every Programmer Should Know](https://97-things-every-x-should-know.gitbooks.io/97-things-every-programmer-should-know/content/en/index.html)》,其中有97个非常不错的编程方面的建议。这篇文章是比较经典的,别被“97”这个数字吓住,你可以快速浏览一下,会让你有不同的感觉的。另外,在工作一段时间后再来读,你会更有感觉。 # 英文能力 必须指出,再往下走,有一个技能非常重要,那就是英文。如果对这个技能发怵的话,那么你可能无缘成为一个程序员高手了。因为我们所有的计算机技术全部来自于西方国家,所以如果你要想成为一个高手的话,那么必须到信息的源头去。英文的世界真是有价值的信息的集散地。你可以在那里,到官网上直接阅读手册,到StackOverflow上问问题,到YouTube上看很多演讲和教学,到GitHub上参与社区,用Google查询相关的知识,到国际名校上参加公开课…… 如果你的英文能力有问题的话,那么基本上来说,你无法成为一个高手。因此,学好英文是非常有必要的,我说的不只是读写,还有听和说。相信你在学校里学过英文,有一定的基础。所以,我给你下面的这些建议。
  • 坚持Google英文关键词,而不是在Google里搜中文。
  • 在GitHub上只用英文。用英文写代码注释,写Code Commit信息,用英文写Issue和Pull Request,以及用英文写Wiki。
  • 坚持到YouTube上每天看5分钟的视频。YouTube上有相关的机器字幕,实在不行就打开字幕。
  • 坚持用英文词典而不是中文的。比如:[剑桥英语词典](https://dictionary.cambridge.org/) 或是 [Dictionary.com](http://www.dictionary.com/) 。你可以安装一个Chrome插件 [Google Dictionary](https://chrome.google.com/webstore/detail/google-dictionary-by-goog/mgijmajocgfcbeboacabfgobmjgjcoja)。
  • 坚持用英文的教材而不是中文的。比如:[BBC 的 Learning English](http://www.bbc.co.uk/learningenglish/) ,或是到一些ESL网站上看看,如 [ESL: English as a Second Language](https://www.rong-chang.com/) 上有一些课程。
  • 花钱参加一些线上的英文课程,用视频和老外练习。
  • # 问问题的能力 提问的智慧([How To Ask Questions The Smart Way](http://www.catb.org/~esr/faqs/smart-questions.html))一文最早是由Eric Steven Raymond所撰写的,详细描述了发问者事前应该做好什么,而什么又是不该做的。作者认为这样能让问题容易令人理解,而且发问者自己也能学到较多东西。 此文一经发出,就广受好评,被广泛转载并奉为经典。该文也有 [简体中文翻译版](http://doc.zengrong.net/smart-questions/cn.html) 被流传着,所以在华人界也是篇很有名的文章。有两个著名的缩写STFW(Search the fxxking web)以及RTFM(Read the fxxking manual)就是出自本文。 另外,还有一个经典的问题叫 [X-Y Problem](http://xyproblem.info/)。对我来说,这是一个很容易犯的错误,所以,你也要小心避免(我曾经在我的Coolshell上写过这个事《[X-Y问题](https://coolshell.cn/articles/10804.html)》)。 然后,你可以到StackOverflow上看看如何问问题的一些提示-- “[FAQ for StackExchange Site](https://meta.stackexchange.com/questions/7931/faq-for-stack-exchange-sites)”。 作为一个程序员,不做伸手党,你必须要读一读这几篇文章,并努力践行。 # 写代码的修养 除了《代码大全》外,你还需要补充一些如何写好代码的知识,有以下几本书推荐。
  • 《[重构:改善既有代码的设计](https://book.douban.com/subject/4262627/)》,这本书是Martin Fowler的经典之作。这本书的意义不仅仅在于"改善既有代码的设计",也指导了我们如何从零开始构建代码的时候避免不良的代码风格。这是一本程序员必读的书。
  • 《[修改代码的艺术](https://book.douban.com/subject/2248759/)》,这本书是继《重构》之后探讨修改代码技术的又一里程碑式的著作,而且从涵盖面和深度上都超过了前两部经典(《代码大全》和《重构》)。作者将理解、测试和修改代码的原理、技术和最新工具(自动化重构工具、单元测试框架、仿对象、集成测试框架等),与解依赖技术和大量开发和设计优秀代码的原则、最佳实践相结合,许多内容非常深入。这本书不仅可以帮你掌握最顶尖的修改代码技术,还可以大大提高你对代码和软件开发的领悟力。
  • 《[代码整洁之道](https://book.douban.com/subject/4199741/)》,这本书提出一种观念:代码质量与其整洁度成正比。干净的代码,既在质量上较为可靠,也为后期维护和升级奠定了良好基础。本书作者给出了一系列行之有效的整洁代码操作实践。这些实践在本书中体现为一条条规则,并辅以来自现实项目正反两面的范例。
  • 《[程序员的职业素养](https://book.douban.com/subject/11614538/)》,这本书是编程大师Bob大叔40余年编程生涯的心得体会,讲解成为真正专业的程序员需要什么样的态度、原则,需要采取什么样的行动。作者以自己以及身边的同事走过的弯路、犯过的错误为例,意在为后来人引路,助其职业生涯迈上更高台阶。
  • 另外,作为一个程序员,Code Review是非常重要的程序员修养。 Code Review对我的成长非常有帮助,我认为没有Code Review的公司都没有必要呆(因为不做Code Review的公司一定是不尊重技术的)。下面有几篇我觉得还不错的Code Review的文章,供你参考。 - [Code Review Best Practices](https://medium.com/@palantir/code-review-best-practices-19e02780015f) - [How Google Does Code Review](https://dzone.com/articles/how-google-does-code-review) - [LinkedIn’s Tips for Highly Effective Code Review](https://thenewstack.io/linkedin-code-review/) 除了Code Review之外,Unit Test也是程序员的一个很重要的修养。写Unit Test的框架一般来说都是从JUnit衍生出来的,比如CppUnit之类的。学习JUnit使用的最好方式就是到其官网上看 [JUnit User Guide](https://junit.org/junit5/docs/current/user-guide/)([中文版](http://sjyuan.cc/junit5/user-guide-cn/))。然后,有几篇文章你可以看看(也可以自行Google): - [You Still Don’t Know How to Do Unit Testing](https://stackify.com/unit-testing-basics-best-practices/) - [Unit Testing Best Practices: JUnit Reference Guide](https://dzone.com/articles/unit-testing-best-practices) - [JUnit Best Practices](http://www.kyleblaney.com/junit-best-practices/) # 安全防范 在代码中没有最基本的安全漏洞问题,也是我们程序员必须要保证的重要大事,尤其是对外暴露Web服务的软件,其安全性就更为重要了。对于在Web上经常出现的安全问题,有必要介绍一下 [OWASP - Open Web Application Security Project](https://www.owasp.org/index.php/Main_Page)。 OWASP是一个开源的、非盈利的全球性安全组织,致力于应用软件的安全研究。其被视为Web应用安全领域的权威参考。2009年,国际信用卡数据安全技术PCI标准将其列为必要组件,美国国防信息系统局、欧洲网络与信息安全局、美国国家安全局等政府机构所发布的美国国家和国际立法、标准、准则和行业实务守则参考引用了OWASP。 美国联邦贸易委员会(FTC)强烈建议所有企业需遵循OWASP十大Web弱点防护守则。所以,对于[OWASP Top 10项目]([https://www.owasp.org/index.php/Category:OWASP_T](https://www.owasp.org/index.php/Category:OWASP_T) op_Ten_Project) 是程序员非常需要关注的最基本的也是最严重的安全问题,现在其已经成了一种标准,这里是其中文版《[OWASP Top 10 2017 PDF 中文版](https://www.owasp.org/images/d/dc/OWASP_Top_10_2017_%E4%B8%AD%E6%96%87%E7%89%88v1.3.pdf)》。 下面是安全编程方面的一些Guideline。 - [伯克立大学的Secure Coding Practice Guidelines](https://security.berkeley.edu/secure-coding-practice-guidelines)。 - [卡内基梅隆大学的 SEI CERT Coding Standards](https://wiki.sei.cmu.edu/confluence/display/seccode/SEI+CERT+Coding+Standards)。 此外,有一篇和HTTP相关的安全文章也是每个程序员必须要读的——《[Hardening Your HTTP Security Headers](https://www.keycdn.com/blog/http-security-headers/)》。 最后想说的是"防御性编程",英文叫[Defensive Programming](https://en.wikipedia.org/wiki/Defensive_programming),它是为了保证对程序的不可预见的使用,不会造成程序功能上的损坏。它可以被看作是为了减少或消除墨菲定律效力的想法。防御式编程主要用于可能被滥用,恶作剧或无意地造成灾难性影响的程序上。下面是一些文章。 - [The Art of Defensive Programming](https://medium.com/web-engineering-vox/the-art-of-defensive-programming-6789a9743ed4)。 - 当然,也别太过渡了,这篇文章可以看看,[Overly defensive programming](https://medium.com/@cvitullo/overly-defensive-programming-e7a1b3d234c2)。 # 软件工程和上线 系统上线是一件比较严肃的事,这表明你写的软件不是跑在自己的机器上的玩具,或是实验室里的实验品,而是交付给用户使用的,甚至是用户付费的软件。对于这样的软件或系统,我们需要遵守一些上线规范,比如,需要认真测试,并做上线前检查,以及上线后监控。下面是几个简单的规范,供你参考。
  • 关于测试,推荐两本书。