在项目开始的初期,以 quick and dirty 的方式开发,开发效率往往很高。
然而好景不长,随着项目铺开,代码规模变大,肮脏的代码的代价开始显现出来。开发效率会持续下降。 如果不闻不问,一段时间以后,代码 bug 丛生,开发效率会降到接近零,任何新功能的加入都异常困难。图中的红色的曲线表示这种情况。
如果尽早开始重构的话(图中的蓝线),重构花掉的这段时间中,由于废弃了一些代码,功能反而会变少,开发效率是负的。重构完成以后,开发效率其实并没有比重构开始时显著提高。开发效率也仍然会随着时间推移而不断下降,重构的价值仅仅只是延缓了这件事情而已。
尽管如此,重构仍然是值得的。重构的代价(第一次重构期间蓝线在红线下方的这部分面积)在重构后很长时间以后得到了弥补(第一次重构以后,蓝线在红线上方的这部分面积)。而不断的重构则是阻止项目失控的唯一办法(如图所示:第二次重构以后,项目又一次远离了泥潭)。
本文探讨了在项目初期采用快速但不规范的开发方式所带来的短期高效与长期困境,并阐述了通过适时重构来提升代码质量的重要性。文章指出重构虽然短期内会使开发效率降低,但从长远来看能够有效避免项目陷入混乱。


被折叠的 条评论
为什么被折叠?



