《代码整洁之道》 读书笔记 一、整洁代码
1. 整洁代码
1.1 要有代码
代码不再是问题;我们应当关注模型和需求。代码很快就能自动产出。这种言论是不正确的。
因为代码呈现了需求的细节,在某些层面上,这些细节无法被忽略或抽象。
即使将来语言的抽象程度继续提升,那么用这种语言开发也同样是代码。同样需要严谨、规范、精确和详细。
1.2 糟糕的代码
写出糟糕代码的原因:
- 赶着推出产品,代码写得乱七八糟。特性越加越多,代码也越来越烂,最后再也没法管理这些代码了。
- 瞟一眼自己亲手造成的混乱,决定弃之而不顾,走向新一天。
- 烂程序居然能运行,然后断言能运行的烂程序总比什么都没有强。
- 有朝一日再回头清理。(勒布朗(LeBlanc)法则:稍后等于永不(Later equals never))。
1.3 混乱的代价
- 代码混乱难以修改和加feature,进度缓慢
- 修改都影响到其他两三处代码。
- 修改者都得对那堆扭纹柴了然于心,这样才能往上扔更多的扭纹柴。
- 为提升生产力不得不加入更多新人,新人不熟悉系统设计造成更多的混乱。
1.3.1 华丽新设计
最后,开发团队造反了,他们告诉管理层,再也无法在这令人生厌的代码基础上做开发。他们要求做全新的设计。于是组建一个新的团队重新开发,保留旧系统,新旧系统同步开发。持续极长时间。我就见过延续了十年之久的。到了完成的时候,新团队的老成员早已不知去向,而现有成员则要求重新设计一套新系统,因为这套系统太烂了。
1.3.2 态度
代码变糟糕,抱怨的原因:
- 需求变化背离了初期设计
- 进度太紧张,没法干好活
- 愚蠢的经理、苛求的用户、没用的营销方式
正确的态度:
- 经理和营销人员指望从我们这里得到必须的信息,然后才能做出承诺和保证;即便他们没开口问,我们也不该羞于告知自己的想法。
- 多数经理想要知道实情,即便他们看起来不喜欢实情。多数经理想要好代码,即便他们总是痴缠于进度。他们会奋力卫护进度和需求;那是他们该干的。你则当以同等的热情卫护代码。
举例论证:
假使你是位医生,病人请求你在给他做手术前别洗手,因为那会花太多时间,你会照办吗?本该是病人说了算;但医生却绝对应该拒绝遵从。为什么?因为医生比病人更了解疾病和感染的风险。医生如果按病人说的办,就是一种不专业的态度(更别说是犯罪了)。
同理,程序员遵从不了解混乱风险的经理的意愿,也是不专业的做法。
1.3.3 谜题
程序员面临的基础价值谜题:之前的混乱拖了自己的后腿。但开发者们背负期限的压力,只好制造混乱。
但这个谜题的最后部分说错了,制造混乱没办法赶上限期,混乱只会立刻拖慢你。做得快的唯一方法——就是始终尽可能保持代码整洁。
1.3.4 整洁代码的艺术
- 明白整洁代码的意义,再去尝试写整洁代码才有意义
- 写整洁代码很像是绘画,能分辨画的好坏和能绘画是两码事(分辨整洁代码和会写也是)
- 写整洁代码,需要遵循大量的小技巧,贯彻刻苦习得的“整洁感”/"代码感"(代码感有些人天生就有,有些人费点劲才能得到)。
1.3.5 什么是整洁代码
Bjarne Stroustrup, C++语言发明者,C++ Programming Language(中译版《C++程序设计语言》)一书作者。
- 代码逻辑应当直截了当,叫缺陷难以隐藏;
- 尽量减少依赖关系,使之便于维护;
- 依据某种分层战略完善错误处理代码;
- 性能调至最优,省得引诱别人做没规矩的优化,搞出一堆混乱来。
- 整洁的代码只做好一件事。
总结:
- 不要重复代码
- 只做一件事
- 表达力(可读性)
- 小规模抽象。
1.4 思想流派
本书会详细介绍关于整洁变量名的想法,关于整洁函数的想法,关于整洁类的想法,如此等等。
实际上,书中很多建议都存在争议。或许你并不完全同意这些建议。这样挺好的。另外一方面,书中列出的建议,乃是我们长久苦思、从数十年的从业经验和无数尝试与错误中得来。无论你同意与否,如果你没看到或是不尊敬我们的观点,就真该自己害臊。
1.5 我们是作者
我们是作者。作者都有读者。实际上,作者有责任与读者做良好沟通。下次你写代码的时候,记得自己是作者,要为评判你工作的读者写代码。
读与写花费时间的比例超过10:1。写新代码时,我们一直在读旧代码。既然比例如此之高,我们就想让读的过程变得轻松,即便那会使得编写过程更难。没可能光写不读,所以使之易读实际也使之易写。
这事概无例外。不读周边代码的话就没法写代码。编写代码的难度,取决于读周边代码的难度。要想干得快,要想早点做完,要想轻松写代码,先让代码易读吧。
1.6 童子军军规
美国童子军一条简单的军规,应用到我们的专业领域:让营地比你来时更干净。
如果每次签入时,代码都比签出时干净,那么代码就不会腐坏。清理并不一定要花多少功夫,也许只是改好一个变量名,拆分一个有点过长的函数,消除一点点重复代码,清理一个嵌套if语句。
你想要为一个代码随时间流逝而越变越好的项目工作。
1.7 前传与原则
本书是我2002年写那本Agile Software Development: Principles, Patterns, and Practices(中译版《敏捷软件开发:原则、模式与实践》,简称PPP)的“前传”。
在本书中,你会发现对不同设计原则的引用,包括单一权责原则(Single Responsibility Principle, SRP)、开放闭合原则(Open Closed Principle, OCP)和依赖倒置原则(Dependency Inversion Principle, DIP)等。
1.8 小结
本书同样也不担保让你成为好程序员。它不担保能给你“代码感”。它所能做的,只是展示好程序员的思维过程,还有他们使用的技巧、技术和工具。
还记得那个关于小提琴家在去表演的路上迷路的老笑话吗?他在街角拦住一位长者,问他怎么才能去卡耐基音乐厅(Carnegie Hall)。长者看了看小提琴家,又看了看他手中的琴,说道:“你还得练,孩子,还得练!”
1.9 参考文献
略