规则 为什么编程应遵循 30 (为什么规则很重要)

规则 为什么编程应遵循 30 (为什么规则很重要)

正文:

本文最初发布 Medium 博客,经原作者 Riccardo Giorato 授权,InfoQ 中文站翻译并分享。

如果你在编程中,不考虑代码长度的话,那么可维护性、未来更新或对代码库的更改,都将会变得异常困难。

方法或函数的大小应该多大呢?

我们都遇到过这样的问题,当一个函数太长的时候。

或者类,或者包,或者任何其他代码块。在某些情况下,任何一段代码都有可能会变得过于庞大,以至于他人无法正确理解。但是,多大才算大呢?

在Code Complete(《代码大全》,金戈等人译,电子工业出版社), Steve McConnell 指出,理论上,一个方法或函数的最佳最大限制是在一个屏幕上可以容纳的行数。

这种“适合屏幕”的尺寸相当于 65~200 行之间的函数的最佳点。这种大小的例程开发成本更低,每行代码的错误也更少,而且它们的可维护性也很高。

如果你写的代码超过了 200 行,那么,你就会进入了“危险区”:代码的可读性和正确性即将开始崩溃。

30 行代码规则

找寻找更严格的指导原则时,你可以在 Stephen Roock 和 Martin Lippert 合著的Refactoring in Large Software Projects(《大型软件项目的重构》,暂无中文版)一书中找到“30”规则:

如果一个元素包含超过 30 个子元素,那么极有可能会存在严重的问题:

你应该遵循这些规则吗?如何做?

使用代码大小作为编码规则还是非常友好的;对于每个开发人员来说,无论年轻还是碾场,都很容易看到、理解。其他度量,如用于度量代码质量的循环复杂度(cyclomatic complexity),通常更难掌握,并且需要外部工具进行检查。

将类或函数长度限制在这些值范围内将是一个更好的起点,而不是对你的团队或开发人员没有真正的参考。你还会发现,当你审查或更新代码时,这“30”规则的真正价值是显而易见的。

试图将这些规则作为法律或强制性规则来执行,反而会让你置于危险之中——这并不是他们的目标。当你在编写方法中写到第 31 行时,你不会希望停下写代码,对吧?

此举将会降低工作速度,并迫使每个人都将代码分解以适应任意的大小限制,这将使他们的代码风格变得更糟,而不是更好。

正如 Jeff Langer 在讨论 Ken Beck 在(《代码整洁之道》,韩磊译,人民邮电出版社)一书中提到的简单设计的四条规则那样:

有时候,要完成一份连贯的工作需要 30 行或多或少的的代码。

更重要的是,在编写类时要小心,要考虑自己在这里添加了多少东西,其他人会理解这些结构和函数的分组吗?我应该分割这个文件呢,还是讲这个类与另一个类合并呢?

“30”规则将会给你带来帮助,但你必须不能让它支配你!

参考文献和资料

作者介绍:

摄影测量师,网页开发人员。

原文链接:

The rule of 30

声明:本文来自用户分享和网络收集,仅供学习与参考,测试请备份。