`
zzhdi
  • 浏览: 76714 次
  • 性别: Icon_minigender_1
  • 来自: 郑州
社区版块
存档分类
最新评论

优质代码的十诫

阅读更多

原文:http://coolshell.cn/?p=1007

 

1.- DRY: Don’t repeat yourself.

10commandements DRY 是 一个最简单的法则,也是最容易被理解的。但它也可能是最难被应用的(因为要做到这样,我们需要在泛型设计上做相当的努力,这并不是一件容易的事)。它意味 着,当我们在两个或多个地方的时候发现一些相似的代码的时候,我们需要把他们的共性抽象出来形一个唯一的新方法,并且改变现有的地方的代码让他们以一些合 适的参数调用这个新的方法。

DRY 这一法则可能是编程届中最通用的法则了,目前为止,应该没有哪个程序员对这一法则存有异议。但是,我们却能发现,一些程序在编写单元测试(unit testing)时忘记了这一法则:让我们相像一下,当你改变一个类的若干接口,如果你没有使用DRY,那么,那些通过调用一系例类的接口的unit test的程序,都需要被手动的更改。比如:如果你的unit test的诸多test cases中没有使用一个标准共有的构造类的方法,而是每个test case自己去构造类的实例,那么,当类的构造函数被改变时,你需要修改多少个test cases啊。这就是不使用DRY法则所带来的恶果。

 

2.- 短小的方法.

至少,我们有下面三个不错的理由要求程序员们写下短小的方法。

  1. 代码会变得更容易阅读。
  2. 代码会变得更容易重用(短方法可以减少代码间的耦合程度)
  3. 代码会变得更容易测试。

3.- 良好的命名规范

使用不错的统一的命名规范可以让你的程序变得更容易阅读和维护,当一个类,一个函数,一个变量的名字达到了那种可以“望文生义”的境界话,我们就可以少一些文档,少一些沟通。文章《编程中的命名设计那点事 》可以给你一些提示。

4.- 赋予每个类正确的职责

一个类,一个职责,这类规则可以参考一下类的S OLID 法则。但我们这里强调的不是一种单一的职责,而是一个正确的职责。如果你有一个类叫Customer,我们就不应该让这个类有sales 的方法,我们只能让这个类有和Customer有最直接关系的方法。

5.- 把代码组织起来

把代码组织起来有两具层次。

  • 物理层组织 :无论你使用什么样的目录,包(package)或名字空间(namespace)等的结构,你需要把你的类用一种标准的方法组织起来,这样可以方便查找。这是一种物理性质的代码组织。
  • 逻辑层组织 : 所谓逻辑层,主要是说,我们如果把两个不同功能的类或方法通过某种规范联系和组织起来。这里主要关注的是程序模块间的接口。这就是我们经常见到的程序模块的架构。

6.- 创建大量的单元测试

单元测试是最接近BUG的地方,也是修改BUG成本最低的地方,同样也是决定整个软件质量好坏的成败的地方。所以,只要有可能,你就应该写更多的,更好的单元测试案例,这样当你未来有相应代码改变的时候,你可以很简单知道你代码的改变是否影响了其它单元。

7.- 经常重构你的代码

软件开发是一种持续的发现的过程,从而让你的代码可以跟上最新的实际需求的变化。所以,我们要经常重构自己的代码来跟上这样的变化。当然,重构是有 风险的,并不是所有的重构都是成功的,也不是我们随时都可以重构代码。下面是两个重构代码的先要条件,以避免让你引入更多的BUG,或是把本来就烂的代码 变得更烂。

  1. 有大量的单元测试来测试。正如前面所说,重构需要用大量的单元测试来做保障和测试。
  2. 每次重构都不要大,用点点滴滴的小的重构来代替那种大型的重构。有太多的时候,当我们一开始计划重构2000行代码,而在3个小时后,我们就放弃这个计划并把代码恢复到原始的版本。所以,我们推荐的是,重构最好是从点点滴滴积累起来的。

8.- 程序注释是邪恶的

这一条一定是充满争议的,大多数程序员都认为程序注释是非常好的,是的,没错,程序注释在理论上是非常不错的。但是,在实际过程序当中,程序员们写 出来的注释却是很糟糕的(程序员的表达能力很有问题),从而导致了程序注释成为了一切邪恶的化身,也导致了我们在阅读程序的时,大多数时候,我们都不读注 释而直接读代码。所以,在这里,我们并不是鼓励不写注释,而是——如果你的注释写得不够好的话,那么,你还不如把更重要的时间花在重构一下你的代码,让你 的代码更加易读,更加清楚,这比会比注释更好。

9.- 注重接口,而不是实现

这是一个最经典的规则了。接口注重的是——“What”是抽象,实现注重的是——“How”是细节。接口相当于一种合同契约,而实际的细节相当于对 这种合同契约的一种运作和实现。运作是可以很灵活的,而合同契约则需要是相对需要稳定和不变的。如果,一个接口没有设计好而需要经常性的变化的话,那我们 可以试想一下,这代来的后果,这绝对会是一件成本很大的事情。所以,在软件开发和调设中,接口是重中之重,而不是实现。然而我们的程序员总是注重于实现细 节,所以他们局部的代码写的非常不错,但软件整体却设计得相对较差。这点需要我们多多注意。

10.- 代码审查机制

所有人都会出错,一个人出错的概率是很大的,两个人出错的概率就会小一些,人多一些,出错的概率就会越来越小。因为,人多了,就能够从不同的角度看 待一个事情,虽然这样可能导致无效率的争论,但比起软件产品release后出现问题的维护成本,这点成本算是相当值得的。所以,这就是我们需要让不同的 人来reivew代码,代码审查机制不但是一种发现问题的最有效的机制,同时也是一种可以知识共享的机制。当然,对于Code Review来说,下面有 几个基本原则:

  • 审查者的能力一定要大于或等于代码作者的能力,不然,代码审查就成了一种对新手的training。
  • 而且,为了让审查者真正负责起来,而不是在敷衍审查工作,我们需要让审查者对审查过的代码负主要责任,而不是代码的作者。 
  • 另外,好的代码审查应该不是当代码完成的时候,而是在代码编写的过程中,不断地迭代代码审查。好的实践的,无论代码是否完成,代码审核需要几天一次地不断地进行。
分享到:
评论

相关推荐

    优质代码的十诫法则知识

    【优质代码的十诫法则知识】是一组指导程序员编写高效、可维护和易于理解代码的原则。这些原则旨在提升代码质量,降低维护成本,并促进团队之间的协作。以下是这十诫法则的详细解读: 1. **DRY (Don't Repeat ...

    我的VBA十诫,指引vba编程的宝典

    ### 我的VBA十诫:指引VBA编程的宝典 #### 一、声明所有变量 在VBA编程中,第一条诫命是**声明所有变量**。这不仅仅是最佳实践,更是确保代码质量和可维护性的关键。通过使用`Option Explicit`语句,在模块的顶部...

    影响你一生的管理哲学:管理十诫

    这是一本奇书,在这本书11条戒律的指引下,无数家公司经营业绩一飞冲天,连惜墨如金的比尔·盖茨都亲自推荐此书,巴菲特更是不吝溢美之词,亲笔作序并极力推荐……从遍布全球的中小企业到如日中天的跨国公司,曾经...

    乾龙创投查立 创业十诫 管理资料.doc

    业务的核心应是提供优质产品和服务。 7) **戒躁**:创业需修炼内功,积累实力,明白成功并非一蹴而就。如沃尔玛和亨利福特的故事所示,长期坚持和不断改进才是关键。 8) **戒言行过态**:创业者应多倾听,少说话,...

    数据十诫(车品觉)

    车品觉所著的《数据十诫》一文中,提出了在数据分析领域中的关键观念与实践原则。首先,文章强调在数据分析中表现明智并非在于增加更多数据或复杂性,而是要去除不必要的复杂和装饰性元素。这一点在当今数据驱动的...

    C程序员十戒

    《C程序员十戒》是C语言编程领域内的一份宝贵指南,由Henry Spencer撰写,旨在帮助程序员们在编码过程中遵循一系列原则,以提高代码的质量、可读性和稳定性。以下是这十条戒律的详细解读: ### 第一戒:勤用Lint,...

    实战电子商务专家所志国从事电子商务必须遵守的“十诫”.doc

    实战电子商务专家所志国从事电子商务必须遵守的“十诫”.doc

    传统企业从事电子商务必须遵守的“十诫”.docx

    以下是中国制造商总裁卜凯军提出的“十诫”,这些原则对于传统企业开展电子商务活动至关重要: 1. **高附加值产品优先**:短期内,选择具有高附加值的产品进行电子商务销售更易获取丰厚利润。例如,外贸电商在3C...

    实战电子商务专家所志国从事电子商务必须遵守的“十诫”(1).doc

    实战电子商务专家所志国从事电子商务必须遵守的“十诫”(1).doc

    背单词之FC背词十诫

    背单词方法 在书上背不下来的单词左边做个星号,每次复习时加以重点记忆,别的单词背一遍,它背两遍作重点复习。而随着复习的遍数的增多,有一些单词旁边的星号会比较多,三星以上的单词就一定时对于你来讲特别难背...

    实战电子商务专家所志国从事电子商务必须遵守的“十诫”(2).doc

    【电子商务十诫详解】 在电子商务领域,实战专家所志国提出了从事电商的“十诫”,旨在提醒传统企业在转型电商过程中避免常见的误区。这十条戒律是根据他多年的营销经验总结得出,对于那些试图进入或正在从事电子...

    Enduring CSS 无水印pdf 0分

    虽然具体内容无法确定,但通常这样的“十诫”会涵盖如何维护单一来源的真相、处理覆盖问题、定义一致的工具使用规则以及确保CSS代码的清晰和一致等方面。 由于文档内容的片段性,未能提供详尽的每一个方面的信息,...

    我看投资银行业务.pptx

    【投行客户服务十诫】进一步阐述了与客户交往的原则,如避免无效竞争,关注主要决策者,注重质量而非数量,倾听客户的需求,并始终维护良好的关系。 客户选择至关重要,投资银行倾向于【抓大放小,优胜劣汰】,优先...

    现代投行业务运作与管理的核心.ppt

    投行业务中的客户服务遵循十诫,如避免追逐非目标项目,关注主要决策者,倾听客户需求,以及重视与关键人物的交往。客户选择方面,倾向于与能提升券商知名度、有持续筹资需求且经济效益显著的企业合作。客户分类为...

    朗道理论物理:量子力学(英文版)

    物理学上,朗道的贡献是多方面的,也许是借用摩西十诫之名,1958年,苏联原子能研究所为了庆贺朗道的50寿辰,曾经送给他一块大理石板,板上刻了朗道平生工作中的10项最重要的科学成果,把他在物理学上的贡献总结为...

    朗道理论物理.量子力学(中文版)

    物理学上,朗道的贡献是多方面的,也许是借用摩西十诫之名,1958年,苏联原子能研究所为了庆贺朗道的50寿辰,曾经送给他一块大理石板,板上刻了朗道平生工作中的10项最重要的科学成果,把他在物理学上的贡献总结为...

    The Little Schemer 4th.mobi

    《The Little Schemer:递归与函数式的奥妙》介绍了Scheme的基本结构及其应用、Scheme的五法十诫、Continuation-Passing-Style、Partial Function、Y-Combinator、Interpreter等内容,并通过这些内容阐述了计算的...

    品牌酒店服务理念.doc

    喜来登的“喜来登十诫”则明确了对职业道德和业务操作的具体要求;万豪的“人服务于人”理念强调了员工在提供优质服务中的关键作用。 这些品牌酒店的成功之处在于他们不仅提供了高质量的住宿环境,更在于他们将服务...

Global site tag (gtag.js) - Google Analytics