WEB开发网
开发学院软件开发Java 追求代码质量: 用代码度量进行重构 阅读

追求代码质量: 用代码度量进行重构

 2009-11-19 00:00:00 来源:WEB开发网   
核心提示: 主动和被动重构那么问题就变成了“我怎么才能知道什么时候该进行重构呢?” 一段代码的可维护性是个主观的问题,但是,追求代码质量: 用代码度量进行重构(2),我们中的多数人都会发现,维护自己编写的代码要比维护其他人编写的代码容易得多,方法的一个逻辑部分被移除,并被赋予自己的方

主动和被动重构

那么问题就变成了“我怎么才能知道什么时候该进行重构呢?” 一段代码的可维护性是个主观的问题。但是,我们中的多数人都会发现,维护自己编写的代码要比维护其他人编写的代码容易得多。但在这点上也有争议 —— 在整个职业生涯中维护自己的代码是最大挑战。没有几个真正的 “代码牛仔” 足够幸运地能够不断地变换工作,而不必修改其他人的代码。对于我们中的多数人来说,必须维护其他人的代码恰恰是程序员生活的一部分。决定代码是否需要重构的方法,通常是主观的。

但是,也有可能客观地判断代码是否应当重构,不论是自己的代码还是别人的代码。在 这个系列前面的文章中,我介绍了如何用代码度量客观地测试代码质量。实际上,可以用代码度量很容易地找出可能难以维护的代码。一旦客观地判断出代码中有问题,那么就可以用方便的重构模式改进它。

总是运行测试用例!

重构别人编写的代码的秘诀是不要把它弄得更糟。在我重构生涯的早期,学到的一件事就是在修改一些东西之前 拥有一个测试用例很重要。我是通过艰苦的一夜,在我自己整理得很好的重构方法中苦苦寻觅,只为找到一个我不小心破坏的别人编写的工作正常的代码之后学到这个教训的,不小心破坏的原因就在于重构之前没有对应的测试用例。请注意我的警告,在自己进行重构之前,总是要运行测试用例!

提取方法模式

Martin Fowler 的书出版之后的几年中,增加了许多新的重构模式分类;但是,迄今为止最容易学习的模式,也可能是最有效的模式,仍然是提取方法(Extract Method) 模式。在这个模式中,方法的一个逻辑部分被移除,并被赋予自己的方法定义。现在被移走的方法体被新方法的调用代替,如图 1 的 UML 图所示:

上一页  1 2 3 4 5  下一页

Tags:追求 代码 质量

编辑录入:爽爽 [复制链接] [打 印]
赞助商链接