zoukankan      html  css  js  c++  java
  • 实验四 代码评审

    实验四 代码评审

    一、实验目的

    1) 了解代码审查的含义;
    2) 掌握相关编程规范检查工具的安装与使用;

    二、实验内容及要求

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

    ●在项目早期就能够发现代码中的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)配置代码审查工具。要求采用屏幕截图的方式配置的过程;

     1.1 确定代码审查工具

    进入github页面克隆需要审查的项目,根据四则运算是java项目,选用使用Alibaba Java Code Guidelines插件

     然后克隆所要检查小组的仓库文件

     1.2 插件的安装

    一开始安装的是checkstyle,但是安装后发现用不了,之后通过咨询同学,在他的建议下选择了Alibaba Java Code Guidelines这个插件

    安装过程如下:在eclipse主界面工具栏中选择Help->Install New Software,再弹出的窗口中选择Add,之后会弹出一个新窗口如下图,然后name可以任意命名如check,在下方的Location中输入Update Site地址:https://p3c.alibaba.com/plugin/eclipse/update ,然后点击Add完毕,安装配置是否成功可通过在工具栏Windows->Preferences->General中是否有Alibaba Code Analysis看出如下图。注:插件配置安装后eclipse会重启。

     

     1.2 代码审查

    通过运行程序,发现程序是可以正常运行,并且符合课程要求

     接着就使用插件进行代码审查

     

     如果代码有问题,则会在出问题的代码行前端出现

    等符号,说明扫描出该行代码有问题,将鼠标放到行端的符号处便能显示出该行代码出问题的原因。

     审查结果在github上提交给该小组

    实验中遇见的问题:

    1、一开始使用的插件虽然可以在离线的情况下安装好(有时候在有网情况下安装最后会出现错误,这时候可以试试离线安装,离线安装需要将压缩包里面两个文件复制到软件目录下)但是在检查代码时却没有反应,这时应该换个插件重新进行配置。

    2、在安装Alibaba Java Code Guidelines插件时,安装最后总是出现错误

    这个时候无论是否离线安装都安装不了,通过百度发现只需要在插件升级页面中“Contact all update sites during install to find required software” 
    默认为选中,修改为不选即可。

    实验小结:

     通过此次代码审查,我能深层的认识到代码规范的重要性,虽然过程有点艰难,但是作为一名程序员,要在平时一点一滴注意,使自己代码趋向于规范化,被检查小组和我们小组做的是一样的课题,通过观察他们的代码我也学到了很多,发现他们的代码比我们的简洁,功能还比较全面,这个值得我去学习。

  • 相关阅读:
    【FPGA篇章四】FPGA状态机:三段式以及书写方法
    【FPGA篇章三】FPGA常用语句:Verilog基本语法要素
    【FPGA篇章二】FPGA开发流程:详述每一环节的物理含义和实现目标
    【FPGA篇章一】FPGA工作原理:详细介绍FPGA实现编程逻辑的机理
    学习python随笔记
    Spring中的@Bean注解、@Configuration注解、@Value
    什么是Maven项目
    SpringBoot(四)thymeleaf+MyBatis+MySql
    SpringBoot(三)thymeleaf+JPA+MySql
    SpringBoot(二)thymeleaf模板的引入
  • 原文地址:https://www.cnblogs.com/penggongwei/p/12889338.html
Copyright © 2011-2022 走看看