一、最根本也是第一步要做的就是,在设计系统架构阶段就需要充分地考虑系统的可扩展性、模块的高聚合性以及接口灵活易用的性。要做到这一点,就和对需求的分析、系统的了解和经验有很大关系了,需要长期的积累和经常对架构的思考与实践。交给团队里面最牛逼的一个人去主导,比较牛逼的几人参与讨论来做这一步吧。
二、选用一个适合需求的开发框架,会让你事倍功半。PHP的框架有很多,各自有各自的特性和优劣,可以比较选择。Python的tornado在做Web应用的时候比较方便。同样前段也需要代码框架的支持,Javascript中jQuery能胜任大多数项目,HTML和CSS可以尝试使用Twitter的Bootstrap。使用框架对代码的健壮性有帮助吗?当然有!因为框架封装实现很多常用的功能,这样我们自己的代码量会大大减少。直观一点讲,代码量少了,bug自然就少了。其实最重要的是代码量少了,程序的逻辑和结构会更加清晰,从而减少Bug的出现。
三、多人协作需要良好的代码管理工具。SVN可以考虑淘汰了,用分布式的GIT。
四、团队还需要统一的开发环境。包括统一的编码规范、统一的语言版本、统一的编辑器配置(tab和空格之类)、统一的文件编码,统一的数据库等等。这样可以完全避免因为环境不同而导致的Bug。
五、较优秀的程序员应该负责较初级的程序员的代码质量,定期对初级程序员的代码进行review。同时团队内部应该有针对性对一些比较复杂或者变态的部分进行code review。
六、对于系统的破窗和肿瘤,要适时适量地清除,绝对不能放任不管。