记得有一年,我参加一家软件企业对《编码规范》的确认评审,规范的作者是公司一位资深技术人员,他在介绍完规范的内容后,补充说道:“我们的规范是参考了微软的《编码规范》,并结合公司实际制定的,执行应该问题不大。”。不错,规范里定义了细致的代码编写要求:变量名的命名、重要代码的注释、代码段的开始-结束完整性等等,参与评审的人员也没有提出其他问题或异议。但在开始执行时,项目组却并不认为编码规范能对实际开发工作有多大的指导作用,变量名的命名,以及代码注释只是保证了代码的可读性,对于编码工作质量的提高并不能起到太大的作用;至于代码段的完整性,对于一个程序员来说这是最基本的技术要求,就算应届大学毕业生也明白这个道理,还需要专门用规范来体现吗?……诸如此类。相信刚才我们看到的情况在许多实施过程改进,尤其是实施CMMI的软件企业中都有遇见过,我也见过不少过程改进人员编写的《编码规范》,或是参考,或是直接抄袭了别的企业的相关规范内容,但变量名、代码注释这些都是其中必不可少的,而其执行时,却变成了“鸡肋”!食之无味(项目组不屑),弃之不可(评估时需要的证据)。
这里我们抛开项目组对规范未理解的原因不谈,难道我们的编码规范仅仅只是为了保证代码有很高的可读性吗?!显然不是的,那么如何去建立真正的编码规范呢?我个人认为,真正地编码规范的建立与完善,需要三个步骤来完成:
第一步,建立企业级公共代码库。由于今天的软件产品开发项目已不大可能是从零编码了,大量的第三方组件、以及成功项目的可复用代码节约了项目组大量地开发时间,也是软件企业宝贵的技术财富,因此,我们需要将应用到了企业产品中的这些组件、复用代码识别出来,并收归组织级进行统一管理,形成公共代码库,提供给企业内所有的项目开发使用。
第二步,建立公共代码的使用规范。有了公共代码库以后,我们需要对库中每一个组件、可复用代码等建立详细的使用规范说明文档,其中应包括:组件或代码的名称、版本、使用场景、优缺点、接口调用方式等,而这就已经形成了初步的编码规范文档了,在这一基础之上,再建立对接口调用代码编写的规范化,保证每一个项目在使用同一控件或复用代码时,其使用方法和编写代码都是统一的,具有可读性等要求,逐步完善规范。
第三步,建立企业级基础框架代码和完善编码规范。企业还需要基于已建立的公共代码库,继续建立起基础框架代码,组织内所有的软件产品开发都应在基础框架代码上实现。这时的编码规范还应根据基础框架的代码编写要求进行适时同步更新,比如:强调代码的可读性、执行效能,以及代码的优化或重构等要求。
经过上述三个步骤,可以看到,要适用于软件企业的编码规范,不仅仅只是一纸文档那么简单,它是与企业生产改进活动密不可分的。由此也可以看出,包括编码规范在内的任何规范性文档,都必须与企业的实际生产经营活动结合起来,才能保证规范具有真正的可执行性,过程改进绝不是仅文档论文档而已。
分享到:
相关推荐
matplotlib-3.6.3-cp39-cp39-linux_armv7l.whl
numpy-2.0.1-cp39-cp39-linux_armv7l.whl
基于springboot个人公务员考试管理系统源码数据库文档.zip
onnxruntime-1.13.1-cp310-cp310-win_amd64.whl
基于springboot的西山区家政服务网站源码数据库文档.zip
Linux环境下,关于C++静态库的封装和调用代码。 TestLib是库目录。 TestLibCall是调用库的目录。
基于springboot软件技术交流平台源码数据库文档.zip
numpy-1.20.1-cp39-cp39-linux_armv7l.whl
ASP.NET酒店管理系统源码(WPF) 一、源码特点 采用WPF进行开发的酒店管理系统源码,界面相当美观,功能齐全 二、菜单功能 1、预订登记:可选择入住时间、离店时间、所在城市、证件类型,保存、删除、查询、返回 2、住宿结算:新增入住、保存、删除、查询、返回 3、今日盘点:查询、返回 4、查询统计: 5、房间管理:增加房间类型、删除类型、增加房间、删除房间、保存、返回 6、用户管理:增加用户、删除用户、保存、返回 7、系统配置:基本功能 8、显示当前系统时间等功能的实现
坠落的天空小游戏图片和代码
论文描述:该论文研究了某一特定领域的问题,并提出了新的解决方案。论文首先对问题进行了详细的分析和理解,并对已有的研究成果进行了综述。然后,论文提出了一种全新的解决方案,包括算法、模型或方法。在整个研究过程中,论文使用了合适的实验设计和数据集,并进行了充分的实验验证。最后,论文对解决方案的性能进行了全面的评估和分析,并提出了进一步的研究方向。 源码内容描述:该源码实现了论文中提出的新的解决方案。源码中包含了算法、模型或方法的具体实现代码,以及相关的数据预处理、实验设计和性能评估代码。源码中还包括了合适的注释和文档,以方便其他研究者理解和使用。源码的实现应该具有可读性、可维护性和高效性,并能够复现论文中的实验结果。此外,源码还应该尽可能具有通用性,以便在其他类似问题上进行进一步的应用和扩展。
环境说明: 开发语言:python Python版本:3.6.8 数据库:mysql 5.7 数据库工具:Navicat11 开发软件:pycharm
基于springboot高校学术交流平台源码数据库文档.zip
onnxruntime-1.16.2-cp310-cp310-win_amd64.whl
基于springboot+vue的实践性教学系统源码数据库文档.zip
基于springboot的校园二手物品交易系统源码数据库文档.zip
numpy-1.23.5-cp39-cp39-linux_armv7l.whl
bimdata_api_client-4.0.2-py3-none-any.whl
环境说明: 开发语言:PHP 框架:原生php/thinkphp5 服务器:Apache 数据库:mysql 5.7(一定要5.7版本) 数据库工具:Navicat 11 运行软件:小皮phpStudy
基于SpringBoot的中老年人文化活动平台源码数据库文档.zip