1.- DRY: Don’t repeat yourself.
DRY 是一个最简单的法则,也是最容易被理解的。但它也可能是最难被应用的(因为要做到这样,我们需要在泛型设计上做相当的努力,这并不是一件容易的事)。它意味着,当我们在两个或多个地方的时候发现一些相似的代码的时候,我们需要把他们的共性抽象出来形一个唯一的新方法,并且改变现有的地方的代码让他们以一些合适的参数调用这个新的方法。
DRY 这一法则可能是编程届中最通用的法则了,目前为止,应该没有哪个程序员对这一法则存有异议。但是,我们却能发现,一些程序在编写单元测试(unit testing)时忘记了这一法则:让我们相像一下,当你改变一个类的若干接口,如果你没有使用DRY,那么,那些通过调用一系例类的接口的unit test的程序,都需要被手动的更改。比如:如果你的unit test的诸多test cases中没有使用一个标准共有的构造类的方法,而是每个test case自己去构造类的实例,那么,当类的构造函数被改变时,你需要修改多少个test cases啊。这就是不使用DRY法则所带来的恶果。
2.- 短小的方法.
至少,我们有下面三个不错的理由要求程序员们写下短小的方法。
-
代码会变得更容易阅读。
-
代码会变得更容易重用(短方法可以减少代码间的耦合程度)
-
代码会变得更容易测试。
3.- 良好的命名规范
使用不错的统一的命名规范可以让你的程序变得更容易阅读和维护,当一个类,一个函数,一个变量的名字达到了那种可以“望文生义”的境界话,我们就可以少一些文档,少一些沟通。
4.- 赋予每个类正确的职责
一个类,一个职责,这类规则可以参考一下类的SOLID 法则。但我们这里强调的不是一种单一的职责,而是一个正确的职责。如果你有一个类叫Customer,我们就不应该让这个类有sales 的方法,我们只能让这个类有和Customer有最直接关系的方法。
5.- 把代码组织起来
把代码组织起来有两具层次。
-
物理层组织:无论你使用什么样的目录,包(package)或名字空间(namespace)等的结构,你需要把你的类用一种标准的方法组织起来,这样可以方便查找。这是一种物理性质的代码组织。
-
逻辑层组织: 所谓逻辑层,主要是说,我们如果把两个不同功能的类或方法通过某种规范联系和组织起来。这里主要关注的是程序模块间的接口。这就是我们经常见到的程序模块的架构。
6.- 创建大量的单元测试
单元测试是最接近BUG的地方,也是修改BUG成本最低的地方,同样也是决定整个软件质量好坏的成败的地方。所以,只要有可能,你就应该写更多的,更好的单元测试案例,这样当你未来有相应代码改变的时候,你可以很简单知道你代码的改变是否影响了其它单元。
7.- 经常重构你的代码
软件开发是一种持续的发现的过程,从而让你的代码可以跟上最新的实际需求的变化。所以,我们要经常重构自己的代码来跟上这样的变化。当然,重构是有风险的,并不是所有的重构都是成功的,也不是我们随时都可以重构代码。下面是两个重构代码的先要条件,以避免让你引入更多的BUG,或是把本来就烂的代码变得更烂。
-
有大量的单元测试来测试。正如前面所说,重构需要用大量的单元测试来做保障和测试。
-
每次重构都不要大,用点点滴滴的小的重构来代替那种大型的重构。有太多的时候,当我们一开始计划重构2000行代码,而在3个小时后,我们就放弃这个计划并把代码恢复到原始的版本。所以,我们推荐的是,重构最好是从点点滴滴积累起来的。
8.- 程序注释是邪恶的
这一条一定是充满争议的,大多数程序员都认为程序注释是非常好的,是的,没错,程序注释在理论上是非常不错的。但是,在实际过程序当中,程序员们写出来的注释却是很糟糕的(程序员的表达能力很有问题),从而导致了程序注释成为了一切邪恶的化身,也导致了我们在阅读程序的时,大多数时候,我们都不读注释而直接读代码。所以,在这里,我们并不是鼓励不写注释,而是——如果你的注释写得不够好的话,那么,你还不如把更重要的时间花在重构一下你的代码,让你的代码更加易读,更加清楚,这比会比注释更好。
9.- 注重接口,而不是实现
这是一个最经典的规则了。接口注重的是——“What”是抽象,实现注重的是——“How”是细节。接口相当于一种合同契约,而实际的细节相当于对这种合同契约的一种运作和实现。运作是可以很灵活的,而合同契约则需要是相对需要稳定和不变的。如果,一个接口没有设计好而需要经常性的变化的话,那我们可以试想一下,这代来的后果,这绝对会是一件成本很大的事情。所以,在软件开发和调设中,接口是重中之重,而不是实现。然而我们的程序员总是注重于实现细节,所以他们局部的代码写的非常不错,但软件整体却设计得相对较差。这点需要我们多多注意。
10.- 代码审查机制
所有人都会出错,一个人出错的概率是很大的,两个人出错的概率就会小一些,人多一些,出错的概率就会越来越小。因为,人多了,就能够从不同的角度看待一个事情,虽然这样可能导致无效率的争论,但比起软件产品release后出现问题的维护成本,这点成本算是相当值得的。所以,这就是我们需要让不同的人来reivew代码,代码审查机制不但是一种发现问题的最有效的机制,同时也是一种可以知识共享的机制。当然,对于Code Review来说,下面有几个基本原则:
-
审查者的能力一定要大于或等于代码作者的能力,不然,代码审查就成了一种对新手的training。
-
而且,为了让审查者真正负责起来,而不是在敷衍审查工作,我们需要让审查者对审查过的代码负主要责任,而不是代码的作者。
-
另外,好的代码审查应该不是当代码完成的时候,而是在代码编写的过程中,不断地迭代代码审查。好的实践的,无论代码是否完成,代码审核需要几天一次地不断地进行。
原文链接:http://www.daimami.com/program/288376.htm
相关推荐
4.C#文本加密解密算法示例源代码.rar 5.C#在开机时自动启动程序.rar 6.C#自定义皮肤.rar 7.CS聊天程序.rar 8.WPF模拟Windows+7气象源码.rar 9.玻璃按钮.rar 10.导出Excel格式.rar 11.导出excel列表.rar 12.动态创建...
因此,我们将基于标题和描述给出五个有助于每天写出优质代码的建议。 ### 每天写出好代码的5个建议 #### 建议一:保持代码简洁 编写简洁明了的代码是提高代码质量的关键。这意味着避免不必要的复杂性,使用直观的...
这本书可能是由InfoQ出版的一份精选集,其中包含了多位专家对于优质代码的洞察和实践经验。博文链接(https://grit.iteye.com/blog/255125)虽然没有提供具体的细节,但通常这样的链接可能会指向作者或相关讨论,为...
【程序员写不出好代码的原因分析】...综上所述,程序员写出优质代码的过程不仅需要个人技术实力,还需要良好的工作环境、合理的管理机制和团队协作精神。克服这些障碍,有助于提升整个开发团队的代码质量和项目成功率。
《代码大全 2 中文版》是一本深受程序员喜爱的经典编程书籍,由...对于标签提到的Java开发者而言,尽管书中的很多概念是跨语言的,但仍然可以为Java程序员提供宝贵的指导,帮助他们提升编程水平,写出更优质的代码。
* 掌握课程设计的基本过程和课程设计报告的撰写方法 系统组成 * 变压器:将市电 AC-220V-50HZ 通过变压器转变为供单片机实现控制和驱动 LED 发光的直流 5V 电压电源 * 彩灯控制器(主控模块):以单片机为核心控制...
《深入解析ZLGFS文件系统源代码》 ZLGFS,全称为ZLG File System,是由周立功公司精心研发...通过深入学习和实践ZLGFS源代码,开发者可以更好地应对嵌入式系统中的文件管理挑战,为各种应用场景提供更优质的解决方案。
在编写高效的单片机C语言代码时,我们不仅追求程序能正常运行,还要注重代码的质量。衡量代码质量的标准包括稳定性...通过上述技巧,我们可以写出更加优化的代码,适应单片机资源有限的环境,同时提升软件工程的品质。
《编程精粹——Microsoft编写优质无错C程序秘诀》一书,由Steve Maguire撰写,姜静波、佟金荣翻译,麦中凡校订,由电子工业出版社出版。本书深入探讨了Microsoft内部用于开发无错C程序的技术和策略,对于希望提升...
在计算机科学领域,代码优化是提高软件性能的关键环节。NIIT的代码优化课程为我们揭示了这一过程的重要性,尤其是在快速发展的...通过不断地学习和实践,我们能够写出更高效、更优质的代码,为软件工程的进步贡献力量。
源代码中可能包含了数据集加载、模型构建、训练过程以及测试评估等模块,这对于学习和实践深度学习,特别是Transformer的应用,是一个极好的资源。通过阅读和运行源码,你可以进一步理解Transformer的工作原理,以及...
本书是真正的程序员的必读之物,在向你展示如何用C++撰写优质代码的同时,它为你提供了对语言彻底而实用的理解。本书是广受赞誉的Exceptional C++的续篇,它采用了行之有效的“提问/解答”的组织形式,提供了用C++...
通过模拟编译器的行为,程序员可以更好地理解代码中可能出现的问题点,并采取措施避免这些问题。 - **第2章:自己设计并使用断言** 断言是一种强大的工具,可以帮助开发者在运行时检测程序状态的有效性。本章详细...
2. **命名约定**:介绍了一套标准的命名规则,以帮助程序员更好地组织和理解代码。 3. **引言**:概述了本书的主要目的和结构。 4. **第一章至第八章**:每一章都深入探讨了一个特定的主题,如数据结构的选择、算法...