Paul DiLascia ( James506译 )
当MSDN杂志让我就我关心的问题写一个专页,我说:“你是说像废除税收,车载电话,或者SUVs?”呵,他们的指的当然是一些关于编程的东西。经过一番思考,我意识到我所关心的问题是书写好的代码。从Redmond到Zwaziland,所有的图书和杂志往往会大肆宣传如何使用最新的API或者某些高级对象,但却没有关于如何写好的代码,什么是好的代码的报道。
一个好的程序很好的运行,没有瑕疵。但是什么内在的原因造就如此的完美?这并不神秘,我们只需要偶尔的提醒自己,无论你是使用c/c++,c#,Java,Basic,Perl,COBOL,还是ASM,进行编码,所有好的编码无不显示出同样的特点:简洁,易读,模块性,分层,设计,效率,优雅和明晰。
简洁意味着你能用五行完成的代码,就不要用十行。这需要你额外的努力去简化,但不要过分以至让代码晦涩难懂。组织,实现和设计的简洁,可以使你的代码更可靠,远离Bug,不出错。
易读就是要让别人能读懂你的代码。需要写好注释,遵循常规进行命名,不要自作聪明的任意命名。例如“taxrate”就比“tr”要好。
模块性是说你的程序像宇宙万物一样。这个世界是由分子组成的,而分子是由原子,电子,核子,夸克,还有弦(如果你相信的话)组成。同样,程序中的大型系统是由一些小的部分组成,而这些小的部分则由更小的模块组成。你可以写一个非常简单的文本编辑器,只含有三部分:移动,插入和删除。正如原子可以以各种奇妙的方式组合,组件可以被重用。
分层让你的程序从内部看像一块夹心蛋糕。应用程序建立在框架之上,而框架建立在操作系统之上,而操作系统又建立在硬件之上。即使是在应用程序内部,仍然需要分层,比如file-document-view-frame等。高层会对低层进行调用(调用下行,响应上行)。低层永远都不会知道上面的高层是什么。如果doc直接调用frame,事情就会变的很糟糕。模块和分层是通过API来定的,API对它们的边界进行限定。由此看来,设计是非常关键的。
设计意味着在你的程序建立之前,需要花时间对它进行很好的设计。毕竟,早期的认真构思比后期的费力调试要合算的多。一个值得称道的准则是用一半的时间进行设计。你需要有一份功能说明书(描述程序做什么)和一份开发计划。所有的API必须书写成档。
效率意味着你的程序运行快而且代价小。不会引起文件,数据链接等的冗余。它仅仅做它应该做的。有序的进行加载与卸载。在函数层面上,你总是可以在测试中不断的进行优化。但在更高的层次,对性能你必须有很好的计划。
优雅就像美,你很难去描述,但却很容易识别。优雅是汇集了简洁,高效和华丽,而创造的一种感觉。如下:
int fact( int n )
{
return n==0 ? 1 : n * fact(n-1);
}
明晰是所有其他特性中最重要的一个。计算机为创造比物理硬件复杂的多的软件系统提供了可能性。编程最大的挑战就是管理复杂性。简洁,易读,模块化,分层,设计,效率和优雅都是非常好的达到明晰的方法,专门用来对付复杂性。
明晰的编码,明晰的设计,明晰的目的。在每一个层面上,你必须真正的理解你所做的,否则就是不明晰。一个不好的程序之所以失败,通常不是由于缺少编码技巧,而是没有一个明确的目标。这就是为什么设计是最重要的原因。它让你诚实,如果你不能写下来,你不能向他人解释,你就没有真正明白你所做的事情。
有太多的东西我没有说,但我必须再补充一点。不到万不得已不要放弃编程的准则,除非你为了得到某种便利,或者你已经陷入窘境,程序已经在运行而且你没有时间去改正。但要记住的是:你不按编程准则,必须要做的足够的巧妙,最好还带一点点美感。如果出了什么问题,不要怪我哦。愉快的编程吧!