代码审查规范

代码审查规范

ID:19555143

大小:62.56 KB

页数:9页

时间:2018-10-03

代码审查规范_第1页
代码审查规范_第2页
代码审查规范_第3页
代码审查规范_第4页
代码审查规范_第5页
资源描述:

《代码审查规范》由会员上传分享,免费在线阅读,更多相关内容在工程资料-天天文库

1、代码审查规范1.CodeReview目的CodeReview是一种用来确认方案设计和代码实现的质量保证机制,通过这个机制我们可以对代码、测试过程和注释进行检查。CodeReview主要用来在软件工程过程中改进代码质量,通过CodeReview可以达到如下目的:·在项目早期就能够发现代码中的BUG。·帮助初级开发人员学习高级开发人员的经验,达到知识共享。·避免开发人员犯一些很常见,很普通的错误。·保证项目组人员的良好沟通。·项目或产品的代码更容易维护。 2.CodeReview的前提条件代码提交审核前,开发者必须确保代码符合如下条件,审核者需要确保所有前提条件都已满足方可开始审查

2、,同时也是审查的主要检查点。·所有代码注释清晰,语法正确,编译通过。·日志代码完整,业务日志、系统日志分开,中文描述,脱敏处理,状态变更,全部清晰明确。·测试代码覆盖全部分支和流程,暂时统一使用工具Emma(各编译器可下载对应插件)进行CoverageCheck。·项目引用关系明确,依赖关系清晰,配置文件描述。 3.CodeReview的审查范围代码的一致性、编码风格、代码的安全问题、脱敏问题、代码冗余、是否正确设计以符合设计要求(性能、功能)与设计文档相同等等。3.1、完整性检查(Completeness)·代码是否完全实现了设计文档中所涉及的所有流程和功能点·代码是否已包含

3、所有所需的业务日志、系统日志、异常日志,日志内容是否完整,日志文件配置是否正确。·代码是否使用缓存等,配置信息是否正确可配置。·代码中是否存在任何没有定义或没有引用到的变量、常数或数据类型等3.2、一致性检查(Consistency)·代码的逻辑是否符合设计文档·代码中使用的格式、符号、结构等风格是否保持一致3.3、正确性检查(Correctness)·代码是否符合制定的标准·所有的变量都被正确定义和使用·所有的注释都是准确的·所有的程序调用都使用了正确的参数个数3.4、可修改性检查(Modifiability)·代码涉及到的常量是否易于修改(如使用配置、定义为类常量、使用专门

4、的常量类等)·代码中是否包含了交叉说明或数据字典,以描述程序是如何对变量和常量进行访问的·代码是否只有一个出口和一个入口(严重的异常处理除外)3.5、可预测性检查(Predictability)·代码所用的开发语言是否具有定义良好的语法和语义·是否代码避免了依赖于开发语言缺省提供的功能·代码是否无意中陷入了死循环·代码是否避免了无穷递归3.6、健壮性检查(Robustness)·代码是否采取措施避免运行时错误(如数组边界溢出、被零除、值越界、堆栈溢出等)3.7、结构性检查(Structuredness)·程序的每个功能是否都作为一个可辩识的代码块存在·循环是否只有一个入口3.8

5、、可追溯性检查(Traceability)·代码是否对每个程序进行了唯一标识·是否有一个交叉引用的框架可以用来在代码和开发文档之间相互对应·代码是否包括一个修订历史记录,记录中对代码的修改和原因都有记录·是否所有的安全功能都有标识3.9、可理解性检查(Understandability)·注释是否足够清晰的描述每个子程序·是否使用到不明确或不必要的复杂代码,它们是否被清楚的注释·使用一些统一的格式化技巧(如缩进、空白等)用来增强代码的清晰度·是否在定义命名规则时采用了便于记忆,反映类型等方法·每个变量都定义了合法的取值范围·代码中的算法是否符合开发文档中描述的数学模型3.10、

6、可验证性检查(Verifiability)·代码中的实现技术是否便于测试·测试代码是否正确,是否覆盖所有流程 4.CodeReview的步骤目前CodeReview步骤暂定如下,试行一段时间再根据问题做调整。1.代码编写者 和 代码审核者 坐在一起,由 代码编写者 按照设计文档中的用例依次讲解自己所写的代码和相关逻辑,可采用从前端到后台的方式,例如从Web层->DAO层。2.代码审核者 在此过程中可以随时提出自己的疑问,同时积极发现隐藏的bug;代码编写者 和 代码审核者 都要对这些bug记录在案,代码编写者 修改后再次提交审核,代码审核者 对应bug记录进行回验。3.代码讲解

7、完毕后,代码审核者 给自己安排几个小时再对代码审核一遍。代码需要一行一行静下心看。同时代码又要全面的看,以确保代码整体上设计优良。4.代码审核者 根据审核的结果编写代码“审核结果”并将“审核记录”和“审核结果”提交至GIT,审核记录和审核结果参见附录I审核记录、附录II审核结果。5.代码编写者 GITpull并根据“审核结果”给出的修改意见,修改好代码,有不清楚的地方可积极向 代码审核者 提出。6.代码编写者 bugfix等全部修改完成后提交 代码审核者 再次进行审核,通过审核则 代码审核者

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。