实验四 代码评审

 一、实验目的

1) 了解代码审查的含义;

2) 掌握相关编程规范检查工具的安装与使用;

二、实验内容及要求

Code Review中文应该译作“代码审查”或是“代码评审”或“代码复查”,是指通过阅读代码来检查源代码与编码标准的符合性以及代码质量的活动。Code Review主要用来在软件工程过程中改进代码质量,通过代码评审可以达到如下目的:

●在项目早期就能够发现代码中的BUG

●帮助初级开发人员学习高级开发人员的经验,达到知识共享

●避免开发人员犯一些很常见,很普通的错误

●保证项目组人员的良好沟通

●项目或产品的代码更容易维护

     代码评审主要内容是编程规范,重构方法,架构设计,性能安全,日志,可读性,扩展性等问题。通过代码评审可查找和修复引入到开发阶段的应用程序的错误,提高软件的整体素质和开发者的技能。代码评审的作用和意义已在很多技术团队内达成共识,可是很多时候并未被有效执行,甚至被认为是一项费时费力的工作。借助一些工具可以更容易,更有效率地来进行Code Review。

1、以小组形式,针对前面“实验一”中所完成的代码,进行代码评审(走查),重点检查以下情况。你也可有查询相关材料,建立更细化的检查清单(check list)

- 程序是否能正常工作,代码是否实现预期的功能,逻辑是否正确。

- 代码是否遵循的编程规范

- 代码是否尽可能的模块化

- 所有的数据输入是否都进行了检查

- 是否有注释,并且描述了代码的意图

- 代码的可理解性和可测试性

2、按“实验二”的分组方式,两人一组,随机分配另一组的代码作为本组评审和分析的对象

一些编码规范的检查工具如下,也可自行查找工具使用。

java语言      

- 采用使用eclipse Checkstyle插件 

- CheckStyle是SourceForge下的一个项目,提供了一个帮助JAVA开发人员遵守某些编码规范的工具。它能够自动化代码规范检查过程,从而使得开发人员从这项重要但枯燥的任务中解脱出来。它可以根据设置好的编码规则来检查代码。比如符合规范的变量命名,方法体的最大行数,重复代码检查等等。

如果你使用idea ,可以使用Alibaba Java Code Guidelines插件,参考链接如下:https://github.com/alibaba/p3c/wiki/IDEA%E6%8F%92%E4%BB%B6%E4%BD%BF%E7%94%A8%E6%96%87%E6%A1%A3

C++语言

- 可使用Google代码规范工具Cpplint。

- Cpplint是一个python脚本,Google使用它作为自己的C++代码规范检查工具,VSCcode可配置Cpplint对C++代码进行规范检查。

python

- 可采用pylint

- Pylint 是一个 Python 代码分析工具,它分析 Python 代码中的错误,查找不符合代码风格标准(Pylint 默认使用的代码风格是 PEP 8,具体信息,请参阅参考资料)和有潜在问题的代码。目前在 eclipse 的 pydev 插件中也集成了 Pylint,VSCcode可安装pylint插件

    当发现了项目存在的问题后,可通过Bug跟踪系统向项目维护者反馈问题(issue),管理Issue的系统称为BTS(Bug Tracking System,Bug跟踪系统)。当今具有代表性的BTS有Redmine、Trac、BugZilla等。GitHub自身也加入了BTS的功能。在GitHub上,可以将它作为软件开发者之间的交流工具。通过github的issues功能开发者可以便捷的发现软件的BUG并报告,想向项目所有人询问或用来追踪各种想法探讨准备实施的任务。

三、实验过程

(1)配置代码审查工具。要求采用屏幕截图的方式配置的过程

因为此次审查的代码是C语言,所以我们小组采用Cpplint代码审查工具,此工具是一个插件,要在python的基础上进行使用,首先我们就来安装python2.7。

在官网下载python 2.7.18,然后默认所有选项完成安装。

接下来进行python环境变量的配置,配置完成后在命令行工具中输入python显示如下图结果,说明python安装成功。

(2)使用工具对原始代码进行评审和分析,记录结果,期间不要有任何修改

从待审查小组的远程仓库中克隆他们的代码,以便进行编码规范的分析。

 

 从网站上下载cpplint,将其放到python27文件中,然后检查cpplintshif是否可用,接下来进行代码检查。

 

Syntax: cpplint.py [–verbose=#] [–output=emacs|eclipse|vs7|junit]
[–filter=-x,+y,…]
[–counting=total|toplevel|detailed] [–repository=path]
[–root=subdir] [–linelength=digits] [–recursive]
[–exclude=path]
[–headers=ext1,ext2]
[–extensions=hpp,cpp,…]
[file] … 使用举例
python C:Python27Libsite-packagescpplint.py youpath o obecheck.cpp 备注
规则过滤,可以从现有规则中决定使用哪些规则来check代码
filter=-x,+y,…
Specify a comma-separated list of category-filters to apply: only
error messages whose category names pass the filters will be printed.
(Category names are printed with the message and look like
“[whitespace/indent]”.) Filters are evaluated left to right.
“-FOO” and “FOO” means “do not print categories that start with FOO”.
“+FOO” means “do print categories that start with FOO”.

(3)对工具执行结果进行人工分析,结合检查清单和人工走查的出代码修改建议

是通过浏览器在网页直接下载licode代码的,而不是通过git clone下载的

代码里面缺少版权声明,C++头文件的宏定义也不规范

 原因是=左右缺少空格符

 

 因为平时写代码的时候经常将左大括号不放在单独的一行

 

原因是,后面没有空格

 空白行里面不能有空格

 

(4)通过github issues向项目维护者提交问题(issue),注意一个issue 只报告一个问题,多个问题需放在多个issue中,以便跟踪

(5)记录总结实验过程中遇到的问题和解决过程

python的版本一定要是2.x,不然可能出现一些问题,在下载cpplint时要把这个文件放在python所在文件下,我在github一直没有成功下载插件,后来直接在命令行工具中进行插件的下载,问题解决。
在进行代码审查时一直找不到相应的文件位置,经过查询得知,要让cpplint文件和代码文件放在同一文件夹下,并且命令行指向该文件夹。
还有就是我们检查小组的issue没有对外开放,经过交流,对方成功开放了issue,我们对代码的问题得到了很好的交流。

原文地址:https://www.cnblogs.com/321ending/p/12885984.html