why reuse? 老板喜欢呗! 当然, 大项目是一定需要!
why rewrite?程序员喜欢.
在面对中小型项目的时候, 为什么程序员宁愿重写组件, 甚至整个项目重写, 也不愿意去重用过去测试稳定的代码?更真实的原因不外乎如下几点:
1.程序员情怀!
一个程序一个作品就像程序员的一个孩子, 这就像生活中, 大多数人宁愿自己生个孩子, 而不愿意领养一个孩子.而在编写与维护层面来说, 找个女人来问, 如果只有生孩子和带孩子的选择, 她们宁愿选择生一个孩子, 而不是带一个孩子.
这就是程序员为什么宁愿重写, 而不愿重用.
领养的孩子, 本身的基因强大倒还好, 本身基因如果不强大, 三天两头这个病哪个病的, 这一些都是自己无法控制的, 但是又是需要自己解决的, 谁乐意?写一个程序就像生个孩子的过程, 麻烦也就生产那么一个过程而已, 顺利过了测试, 痛苦也就结束了. 带一个孩子, 就像维护别人的代码, 这种跟带孩子一样的一把屎尿的带大, 工作量....还不如自己做一个.
2.还是程序员情怀!
前任写的组件, 我也能写啊, 凭什么我就比不过他? 而不同程序员的阅历不同, 标准也就不一样, 在不同标准中, 就会互相排斥, 比如阿里代码规范表名就是单数, 但是laravel要表名就是复数, 为嘛我要用你的标准? 我写API比你规范, 为嘛我还得要用你的API,为嘛你遍出来的几个单词还需要我来背, 你又不是规范.......就是我未必不如你, 我没必要跟随你!
再者,如Joel Spolsky 在《你永远不要做的事》中所说:
我们是程序员。程序员是什么?在他们内心深处,认为自己是建筑师。当他们初次去某地时,第一件事就是推平这块地,然后从头开始,建造出一些宏伟的东西来。修修补补,优化改良,培养花圃这些后加的整修,我们并不感到兴奋。
3. 阅读代码太难!
无论是刚写程序的, 还是做程序的老手, 有一个痛苦的领悟是: 阅读别人的代码比自己写代码要难的多.
人的趋利避害, 自然选择的结果是, 更喜欢重写, 而非花大量的精力去阅读学习别人的代码.
4.写代码=学习过程
正如JeremyK在Eric Lippert博客中问到:
你是怎么教人们快速深入挖掘不熟悉的代码(不是自己所写的)?我学习如何编程的方法很传统 —— 自己动手编码。但我现在很纠结:到底是集中精神阅读源码,还是自己编写。对我而言,似乎唯一有效的方法就是自己写过。
程序员的学习之路往往都是从敲代码中学出来的, 而生产中写每一个组件的过程, 就是自己在学习的一个过程, 有时候我们看见前人写的代码很好, 但是自己如果没有敲一遍, 心里就没底, 怎么都感觉自己好像没学会. 当然, 如果是特大牛写的组件, 出于崇拜大体上没人会去重写, 比如几乎的程序员在用框架和第三方代码, 却比较少自己去重写框架代码和第三方组件, 因为那是标准, 心理上认为那是不会错的, 所以不会去重写.
但是公司内部人写的代码, 大家都半斤八两, 你写的东西, 我没学过, 那么就会自己也去写一遍, 因为我没写一遍我不懂啊, 可是我抄一遍, 要学会还是你的思想, 那么, 不如重写!
实际角度上看:
现实中愿意重写代码而不重用的理由会是各种各样的: 前任的代码实在太烂, 代码运行效率太低.....
但是, 我认为技术上的理由很多时候是不成立的! 因为你重写的代码未必会比前任的代码更好, 如果会, 也很大的可能是你觉得, 当一个心理上不想去重写的时候, 往往技术上的理由只是拿作辅证来说明心理的想法而已.
一个人想装睡的时候, 往往是叫不醒的, 叫醒的话, 会在技术上论证为什么会睡着, 不然, 他就不是做技术的啦^_^