代码质量是咱们程序开发中永远的一个痛,提升代码质量有很多种方式,强化管理是一种很常见的方式,这里咱们就聊聊,所谓的管理,真的是提升代码质量最有效的方式吗?
外包团队进行代码实现,可以吗?
很多企业喜欢将系统的代码实现细节交由外包团队处理,声称只要产品设计的合理,只要架构合理,只要代码规范合理,代码的实现找谁实现都是一样的,所以干脆找外包团队来实现,这应该是很多非互联网公司,特别是传统企业的思路。但是,结果真的是这样吗?
经历过的人应该都是有很深的感触的,外包团队开发的代码和公司内部人员开发的代码,质量上是有很大的扯别的,且不论这是因为技术本身的差别,因人而异,因环境而异,因心态而异产生的代码就有很大的不同。
软件是一个工程化的产品,那么工程化产品的特点是什么?
长期运营维护
频繁的变更
高频沟通
你让一个没有融入感的人去做这些事情,会有一个好的结果吗?都说做菜要用心去做,其实编程也是需要用心去完成的工作,一个小的疏忽都可能会造成严重的后果,公司内部人都无法100%保证,外包团队能保证吗?
最后说明下,外包不会节省成本,从短期来看,人员成本不会少,可能只是降低了一定的人员异动风险,长期来看,是一项非常不划算的投入。
代码质量通过奖惩来进行强制执行,可以吗?
以前一直看到网上的段子,有的公司通过bug数量来判断一个人的绩效,例如:bug多的程序员,绩效评分低;测出bug多的测试工程师,绩效评分高。本来一直以为是段子,后来接触的人多了,发现很多非IT专业的管理者都有这样的想法,虽然,在我个人和团队的强烈反对下没有执行,但是,这种思想对很多人来说是根深蒂固。通过奖惩能有效提高代码的质量吗?
没有一个软件是完美的软件,所有的软件都是有BUG,“上次造人都有BUG,何况人制造软件呢?”大如微软这样几十年的老牌IT企业,还是BAT这样的新兴互联网大厂,即使项目投入的人再多,再优秀,也是无法保证软件是没有BUG的。而且如有根据BUG来考评,有两个非常严重的问题:
多做多错,那么我不做或者少做,那么BUG就很少了。
发现BUG,不愿意暴露BUG,而是偷偷的处理掉。
这与鼓励创新、鼓励分享的IT技术显然是背道而驰的。
建立良好的代码审查制度,可以吗?
为了提高代码质量,团队都会定义代码审查的制度,如“工作经验不足**年的代码必须由主管审查”,“新入职员工的代码必须师傅审查”,“开发经理定期对核心代码进行审查”等,这些规定实际也是有一定的作用的,至少对统一新同事的代码规范,提升经验尚浅的开发人员能力是有作用的,但是因为更多的依赖于人工的审查,实施起来难度比较大,而且很难坚持。之前,我们团队就坚持了一段时间这样的方式,SVN获取代码后对关注的人员的代码进行审查,但是单凭个人或者少数几个人的处理,时间一长,基本又回到原点。
其实我也一直有个疑问,真有结对编程的公司吗??开发工程师都是属于高强度工作,公司恨不得让程序员一个人写两个人的代码,怎么会两个人写一份代码。
也许我们需要找到更加先进的方法来代替纯人工的方式。
招聘更优秀的程序员
“一个优秀的程序员的效率,比100个差的程序员效率都要高。”类似的结论是IT界是非常流行的,虽然不同的程序员在能力差100倍是有点夸张了,但是一个优秀的程序员,抵5个差的程序员这样的事情在我们身边肯定是经常发生的。
我一直都认为,程序开发是一个非常需要创造性的工作,即使是简单的增删改查,不同的业务场景应该是不一样的实现逻辑和技术手段,我们在脑子里面思考问题所花费的经历真的比实现代码花费精力多得多。
优秀的程序员效率更高,效率的差距可能会出现好几倍的差距。而且,优秀的程序员,真的是BUG很少。一个简单的插入操作,优秀的程序员想到的是:如何确保事务的一致性、如何防止连续点击导致重复数据、多表的插入是否可以并行提升效率,而差的程序员只会考虑最理想的外部情况,其他的问题都是环境的问题或者操作人员的问题。难道这些,上线后出现问题了,最终就不是BUG了??最后还是需要开发人员来解决。
注重公司内部人员的培养
接上一个话题,想得到优秀的程序员无非就两种方式,招聘或者培养。前文也有说过要建立良好的代码审查制度,虽然不是一个银弹,但还是有一定作用的。其实,代码审查也可以看做是内部培养的一种方式。每个公司除了业务上的不同,我们这里暂不讨论,每个公司代码都有自己的一个风格,统一代码的风格,其实提升代码质量一个很好的方式,公司都会有自己的代码最佳实践,如业界经常流传的《阿里巴巴代码规范》《58同城数据库军规》等。所以,多花点时间让公司员工统一代码风格,能让整体代码质量有明显的提升。
同时,很多的BUG除了是技术上的问题,更多是对于业务的不了解。有个长期稳定,并且能产生默契的团队,除了有更高的效率,也能减少BUG的数量。
自动化+人工的方式提升团队能力
前文多次提到代码审查,代码审查这个方式显然是能提升代码质量的,但是涉及的审查覆盖率的问题,无法发挥全部作用,如果有个自动化的方式进行代码审查,那么应该就是一个相对比较完善的解决方案了。
现在的代码管理都是通过CVS工具进行管理的,基本都是git或者svn,通过代码管理工具进行自动化的代码审查就是一个非常好的方式。用户提交代码的时候,强制使用静态的代码审查工具(常见如findbug,checkstyled等)进行审查,无法通过审查的,代码是无法提交的。虽然代码审查工具现阶段还不是非常智能,但是基础的代码规范,空指针预测等检测还是比较完善的,能很大程度上避免重复的人工审查工作。
movefast的审查方式是很多互联网公司现在执行的一种人工审查方式,代码的commit、push必须有两个人执行,push的操作者必须审查commit的代码,这样基本能保证人工审查的覆盖率,对提升代码的质量有很大帮助。
这里提到人工的方式,那么人工的方式我们应该注意哪些呢?静态代码扫描工具能帮忙解决很多基础的代码问题,我们更多应该关注哪些静态代码检查工具无法找到的问题:
关注循环体内的问题,循环体内调用外部服务,循环体内查询数据库等。
涉及多线程或者其他异步处理的代码
trycatch的使用,特别是catch中的代码
静态变量使用的问题
这些问题都是进行测试时都很难发现的问题,但是在生产环境却很容易暴露的问题。
总结
代码质量的提升是作为开发人员,特别是开发管理人员非常关注的问题,但是,要达到非常好的效果,却是没有银弹的。
所有的管理制度、管理模式等,对于创造性的工作职位实际是不会有太大的帮助,“优秀的人”才是提升代码质量最好的武器,自动化的方式结合优秀的人,也许是你想要的最佳途径。