`
xiangkun
  • 浏览: 99937 次
  • 性别: Icon_minigender_1
  • 来自: 马尔代夫
社区版块
存档分类
最新评论

如何写好优质的代码

阅读更多

1.- DRY: Don’t repeat yourself.

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

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

 

2.- 短小的方法.

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

  1. 代码会变得更容易阅读。

  2. 代码会变得更容易重用(短方法可以减少代码间的耦合程度)

  3. 代码会变得更容易测试。

3.- 良好的命名规范

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

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

一个类,一个职责,这类规则可以参考一下类的SOLID 法则。但我们这里强调的不是一种单一的职责,而是一个正确的职责。如果你有一个类叫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。

  • 而且,为了让审查者真正负责起来,而不是在敷衍审查工作,我们需要让审查者对审查过的代码负主要责任,而不是代码的作者。

  • 另外,好的代码审查应该不是当代码完成的时候,而是在代码编写的过程中,不断地迭代代码审查。好的实践的,无论代码是否完成,代码审核需要几天一次地不断地进行。

 

     原文链接:http://www.daimami.com/program/288376.htm

 

分享到:
评论

相关推荐

    教你如何写出优质的代码(C程序代码风格经典)

    你还在为写不出很好的代码而感到忧愁吗?你还在由于没有好的代码风格而感到难过吗?现在这里有你所需要的,它将教你如何写出优质的代码!

    如何写出高效优美的单片机C语言代码

    程序能跑起来并不见得你的代码就是很好的c代码了,衡量代码的好坏应该从以下几个方面来看  1,代码稳定,没有隐患。  2,执行效率高。  3,可读性高。  4,便于移植。  下面发一些网上看到的技巧和自己的...

    More Exceptional C++

    本书是真正的程序员的必读之物,在向你展示如何用C++撰写优质代码的同时,它为你提供了对语言彻底而实用的理解。本书是广受赞誉的Exceptional C++的续篇,它采用了行之有效的“提问/解答”的组织形式,提供了用C++...

    计算机毕业设计:Java实现的办公自动化系统(源代码+论文+外文翻译),保证可靠运行,附赠计算机答辩PPT模板

    源代码中包含了办公自动化系统的核心功能,如文档管理、任务分配、日程安排等,为学生提供了一个实践Java编程和了解办公自动化流程的优质平台。 此外,资源包中的论文部分对办公自动化系统的设计理念、技术实现以及...

    c语言编程精粹-怎样编写优质无错程序

    怎样写好c程序的秘诀,教你怎样把代码写得更好

    用 VS 2022 和 SQL Server 2017 完成数据库销售系统设计

    内容:资源是用 VS 2022 和 SQL Server 2017 完成数据库销售系统设计 (内容优质,可拿高绩点) 里面有用VS建立好的系统,也有相应的数据库文件和数据库日志文件,还有讲解报告(报告是按毕业设计论文的标准来写的)...

    销售管理系统设计(SQL+VS)

    内容:资源是用 VS 2022 和 SQL Server 2017 完成数据库销售系统设计 (内容优质,可拿高绩点) 里面有用VS建立好的系统,也有相应的数据库文件和数据库日志文件,还有讲解报告(报告是按毕业设计论文的标准来写的)...

    设计模式——6大软件设计原则(demo案例实现,附带解析,快速掌握软件设计原则的精髓)

    写出耦合度低、易于扩展、更容易维护的优质代码 代码中的注释信息,通俗易懂,凝结了本人的思考,让你更快掌握软件设计的基本原则 阅读建议: 建议先看一遍软件设计基本原则的概念,然后带着概念看此包内的demo...

    编程方面的好习惯

    是初学编程的人应该懂得的基本知识,使其了解如何写出优质高效的代码

    C 编程精粹

    C编程精粹 --Micorsoft编写优质无错C程序秘诀。对写好C代码很有好处

    构建ASP.NET MVC4+EF5+EasyUI+Unity2.x注入的后台管理系统

    1. ASP.NET MVC 基础 为什么选择MVC,假如您是个有梦想的人,那么你也...7. T4模版或代码生成器,有了T4模版,妈妈再也不用当心我写代码了要熬夜了 8. MVC4 用微软自带的报表制作报表在razor视图展示和导出 9. 扩展....

    单元测试学习笔记之四

    有的开发人员认为,测试代码不是交付给最终用户的产品代码,只是内部测试使用的,因此其质量比...因此,要么我们不写测试代码,要么就必须写出"好的"测试代码.所以,我们希望树立起这样的观念:测试代码绝不是二等公民,必须

    小米soar SQL 优化建议工具

    大家都知道数据库中的explain执行计划工具,能帮我们分析自己所编写SQL的性能,如索引是否使用了、临时表是否使用了、...而此时小米开源的soar工具能帮我将explain里面的信息解读出来,提示我们写出更加优质的sql代码。

    code-nav:最专业的编程导航,发现优质编程学习资源!公众号『编程导航』

    包含多个子项目,都开源给大家学习,使用这套代码,你也能轻松开发多端适应网站! :magnifying_glass_tilted_left: :house_with_garden: :books:深入了解项目必读 项目展示 写在前面 总是有很多学编程的朋友问我...

    VB XML文件读取并操作类

    本站是一个免费的基于VB,VB.NET源代码交流的平台,为大家提供优质的专业的源代码,如果您有需要,本站可以帮助在业余时间里给您寻找代码。当然,如果您有好的代码也可以在本站发布,共享给大家。

    Writing Clean Code

    本文档包含中英文版及word版本!作者系C程序顶尖高手 该手册最初是为微软程序员编写的 书中主要描述如何写出优质无错的C程序 值得广大C/C++各阶段程序员参考 好的编程习惯是写出好代码的前提。

    HTML5入门到精通-精读

    学习html5不可多得的好材料,内容不多,但是很精简,省去了你花费大量时间去全读的困扰,这本书你可以用几个小时就能全部读完,然后开始写出html5的优质代码。

    Blender建模高级教程

    开源并不是意味着你自己需要亲自动手写代码,而是有大量优质且免费的插件各路大神已经写好了,可以补充Blender本身的短板。本文主要分功能模块全面介绍一下 Blender ,同时会介绍一些非常能打的参数化和节点化插件,...

    Android优质索尼滚动相册

    其桌面小部件滚动相册我觉得也挺好的,比谷歌原生的相册墙功能好多了,网上搜了一下也没发现有人写这个,于是,下面就介绍下我的高A货。  首先是效果图:   主要手势操作有:  1.上/下满速移动,可以上滑/...

Global site tag (gtag.js) - Google Analytics