Files
CategoryResourceRepost/极客时间专栏/左耳听风/技术基础/07 | 推荐阅读:每个程序员都该知道的知识.md
louzefeng d3828a7aee mod
2024-07-11 05:50:32 +00:00

166 lines
12 KiB
Markdown
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

在整个为期一年的专栏内容中,我会逐步向你推荐一些有价值的内容,供你参考,这些内容有中文,有英文,也有视频,它们都是我认为对我非常有价值的信息,我也希望它们对你能有同样的帮助和启发。
今天我为你推荐的5篇文章它们分别是
- Stack Overflow上推荐的一个经典书单
- 美国某大学教授给计算机专业学生的一些建议,其中有很多的学习资源;
- LinkedIn的高效代码复查实践很不错的方法值得你一读
- 一份关于程序语言和bug数相关的有趣的报告可以让你对各种语言有所了解
- 最后是一本关于C++性能优化的电子书。
#### 每个程序员都应该要读的书
在Stack Overflow上有用户问了一个[问题](https://stackoverflow.com/questions/1711/what-is-the-single-most-influential-book-every-programmer-should-read),大意是想让大家推荐一些每个程序员都应该阅读的最有影响力的图书。
虽然这个问题已经被关闭了,但这真是一个非常热门的话题。排在第一位的用户给出了一大串图书的列表,看上去着实吓人,不过都是一些相当经典相当有影响力的书,在这里我重新罗列一些我觉得你必须要看的。
<li>
**《代码大全》** 虽然这本书有点过时了,而且厚到可以垫显示器,但是这绝对是一本经典的书。
</li>
<li>
**《程序员修练之道》** 这本书也是相当经典,我觉得就是你的指路明灯。
</li>
<li>
**《计算机的构造和解释》** 经典中的经典,必读。
</li>
<li>
**《算法导论》** 美国的本科生教材,这本书应该也是中国计算机学生的教材。
</li>
<li>
**《设计模式》** 这本书是面向对象设计的经典书籍。
</li>
<li>
**《重构》** 代码坏味道和相应代码的最佳实践。
</li>
<li>
**《人月神话》** 这本书可能也有点过时了。但还是经典书。
</li>
<li>
**《代码整洁之道》** 细节之处的效率,完美和简单。
</li>
<li>
**《Effective C++》/《More Effective C++》** C++中两本经典得不能再经典的书。也许你觉得C++复杂但这两本书中带来对代码稳定性的探索方式让人受益因为这种思维方式同样可以用在其它地方。以至于各种模仿者比如《Effective Java》也是一本经典书。
</li>
<li>
**《Unix编程艺术》、《Unix高级环境编程》**也是相关的经典。
</li>
还有好多,我就不在这里一一列举了。你可以看看其它的答案,我发现自己虽然读过好多书,但同样还有好些书没有读过,这个问答对我也很有帮助。
#### 每个搞计算机专业的学生应有的知识
**[What every computer science major should know](http://matt.might.net/articles/what-cs-majors-should-know/)**,每个搞计算机专业的学生应有的知识。
本文作者马修·迈特Matthew Might是美国犹他大学计算机学院的副教授2007年于佐治亚理工学院取得博士学位。计算机专业的课程繁多而且随着时代的变化科目的课程组成也在不断变化。
如果不经过思考,直接套用现有的计算机专业课程列表,则有可能忽略一些将来可能变得重要的知识点。为此,马修力求从四个方面来总结,得出这篇文章的内容。
1. 要获得一份好工作,学生需要知道什么?
1. 为了一辈子都有工作干,学生需要知道什么?
1. 学生需要知道什么,才能进入研究生院?
1. 学生需要知道什么,才能对社会有益?
这篇文章不仅仅对刚毕业的学生有用,对有工作经验的人同样有用,这里我把这篇文章的内容摘要如下。
首先对于我们每个人来说作品集Portfolio会比简历Resume更有参考意义。所以在自己的简历中应该放上自己的一些项目经历或是一些开源软件的贡献或是你完成的软件的网址等。最好有一个自己的个人网址上面有一些你做的事、自己的技能、经历以及你的一些文章和思考会比简历更好。
其次,计算机专业工作者也要学会与人交流的技巧,包括如何写演示文稿,以及面对质疑时如何与人辩论的能力。
最后他就各个方面展开计算机专业人士所需要的硬技能工程类数学、Unix哲学和实践、系统管理、程序设计语言、离散数学、数据结构与算法、计算机体系结构、操作系统、网络、安全、密码学、软件测试、用户体验、可视化、并行计算、软件工程、形式化方法、图形学、机器人、人工智能、机器学习、数据库等等。详读本文可以了解计算机专业知识的全貌。
这篇文章的第三部分简直就是一个知识资源向导库,给出了各个技能的方向和关键知识点,你可以跟随着这篇文章里的相关链接学到很多东西。
# LinkedIn高效的代码复查技巧
**[LinkedIns Tips for Highly Effective Code Review](https://thenewstack.io/linkedin-code-review/)**LinkedIn的高效代码复查技巧。
对于Code Review我曾经写过一篇文章 《[从Code Review谈如何做技术](https://coolshell.cn/articles/11432.html)》讲述了为什么Code Review是一件很重要事情。今天推荐的这篇文章是LinkedIn的相关实践。
这篇文章介绍了LinkedIn内部实践的Code Review形式。具体来说LinkedIn的代码复查有以下几个特点。
<li>
从2011年开始强制要求在团队成员之间做代码复查。Code Review带来的反馈意见让团队成员能够迅速提升自己的技能水平这解决了LinkedIn各个团队近年来因迅速扩张带来的技能不足的问题。
</li>
<li>
通过建立公司范围的Code Review工具这就可以做跨团队的Code Review。既有利于消除bug提升质量也有利于不同团队之间经验互通。
</li>
<li>
Code Review的经验作为员工晋升的参考因素之一。
</li>
<li>
Code Review的一个难点是Reviewer可能不了解某块代码修改的背景和目的。所以LinkedIn要求代码签入版本管理系统前就对其做清晰的说明以便复查者了解其目的促进Review的进行。
我认为这个方法实在太赞了。因为我看到很多时候Reviewer都会说不了解对方代码的背景或是代码量比较大而无法做Code Review然而他们却没有找到相应的方法解决这个问题。
LinkedIn对提交代码写说明文档这个思路是一个非常不错的方法因为代码提交人写文档的过程其实也是重新梳理的过程。我的个人经验是写文档的时候通常会发现自己把事儿干复杂了应该把代码再简化一下于是就会回头去改代码。是的写文档就是在写代码。
</li>
<li>
有些Code Review工具所允许给出的反馈只是代码怎样修改以变得更好但长此以往会让人觉得复查提出的意见都表示原先的代码不够好。为了提高员工积极性LinkedIn的代码复查工具允许提出“这段代码很棒”之类的话语以便让好代码的作者得到鼓励。我认为这个方法也很赞正面鼓励的价值也不可小看。
</li>
<li>
为Code Review的结果写出有目的性的注释。比如“消除重复代码”“增加了测试覆盖率”等等。长此以往也让团队的价值观得以明确。
</li>
<li>
Code Review中不但要Review提交者的代码还要Reivew提交者做过的测试。除了一些单元测试还有一些可能是手动的测试。提交者最好列出所有测试过的案例。这样可以让Reviewer可以做出更多的测试建议从而提高质量。
</li>
<li>
对Code Review有明确的期望不过分关注细枝末节也不要炫技而是对要Review的代码有一个明确的目标。
</li>
# 编程语言和代码质量的研究报告
**[A Large-Scale Study of Programming Languages and Code Quality in GitHub](https://cacm.acm.org/magazines/2017/10/221326-a-large-scale-study-of-programming-languages-and-code-quality-in-github/)**,编程语言和代码质量的研究报告。
这是一项有趣的研究。有四个人从GitHub上分析了728个项目6300万行代码近3万个提交人150万次commits以及17种编程语言如下图所示他们想找到编程语言对软件质量的影响。
<img src="https://static001.geekbang.org/resource/image/83/fa/83a8e04f9d2c0725c1b519f6456349fa.png" alt="" />
然后他们还对编程语言做了一个分类想找到不同类型的编程语言的bug问题。如下图所示
<img src="https://static001.geekbang.org/resource/image/89/8d/896d4909cb9e980dbc48c87adb51c48d.png" alt="" />
以及,他们还对这众多的开源软件做了个聚类,如下图:
<img src="https://static001.geekbang.org/resource/image/b5/15/b5ff49830df9bdaabd42588a89ecb915.png" alt="" />
对bug的类型也做了一个聚类如下图
<img src="https://static001.geekbang.org/resource/image/70/ed/70a562303a472634cf7bf801951b72ed.png" alt="" />
其中分析的方法我不多说了。我们来看一下相关的结果。
首先,他们得出来的第一个结果是,从查看 bug fix的commits的次数情况来看C、C++、Objective-C、PHP和Python中有很多很多的commits都是和bug fix相关的而Clojure、Haskell、Ruby、Scala在bug fix的commits的数上明显要少很多。
下图是各个编程语言的bug情况。如果你看到是正数说明高于平均水平如果你看到是负数则是低于平均水平。
<img src="https://static001.geekbang.org/resource/image/a6/a7/a61c4f959ce7775e3d050320638553a7.png" alt="" />
第二个结论是函数式编程语言的bug明显比大多数其它语言要好很多。有隐式类型转换的语言明显产生的bug数要比强类型的语言要少很多。函数式的静态类型的语言要比函数式的动态类型语言的程序出bug的可能性要小很多。
第三研究者想搞清是否bug数会和软件的领域相关。比如业务型、中间件型、框架、lib或是数据库。研究表明并没有什么相关性。下面这个图是各个语言在不同领域的bug率。
<img src="https://static001.geekbang.org/resource/image/65/43/65cdbf74558d61d46eda9f92b35c8e43.png" alt="" />
第四研究人员想搞清楚bug的类型是否会和语言有关系。的确如此bug的类型和语言是强相关性的。下图是各个语言在不同的bug类型的情况。如果你看到的是正数说明高于平均水平如果你看到的是负数则是低于平均水平。
<img src="https://static001.geekbang.org/resource/image/9f/e4/9fa7b680469ca450af150ff82b07a4e4.png" alt="" />
也许,这份报告可以在你评估编程语言时有一定的借鉴作用。
# 电子书《C++软件性能优化》
**[Optimizing Software in C++ - Agner Fog](http://agner.org/optimize/optimizing_cpp.pdf)** - PDFC++软件性能优化。
这本书是所有C++程序员都应该要读的一本书它从事无巨细地从语言层面、编译器层面、内存访问层面、多线程层面、CPU层面讲述了如何对软件性能调优。实在是一本经典的电子书。
Agner Fog还写了其它几本和性能调优相关的书你可以到这个网址[下载](http://www.agner.org/optimize/)。
- Optimizing subroutines in assembly language: An optimization guide for x86 platforms
- The microarchitecture of Intel, AMD and VIA CPUs: An optimization guide for assembly programmers and compiler makers
- Instruction tables: Lists of instruction latencies, throughputs and micro-operation breakdowns for Intel, AMD and VIA CPUs
- Calling conventions for different C++ compilers and operating systems
我今天推荐的内容比较干,都需要慢慢吸收体会,当然最好是能到实践中用用,相信这样你会有更多的感悟和收获。另外,不知道你还对哪些方面的内容感兴趣,欢迎留言给我。我后面收集推荐内容的时候,会有意识地关注整理。