代码静态分析工具--PMD,Findbugs,CheckStyle

  最近学习Mybatis的官方文档,看到了【项目文档】一节有很多内容没有见过,做个笔记,理解一下。

  

PMD 扫描Java代码,查找潜在的问题,如:

  • 可能的bugs,如空的try/catch/finally/switch声明
  • 死亡的代码,没有使用的本地变量,参数和私有方法
  • 不合标准的代码,如String/StringBuffer用法
  • 过于复杂的表达式,如不必要的if表达式
  • 重复的代码,拷贝、粘贴的代码

 

FindBugs 它用来查找Java代码中存在的bug。它使用静态分析方法标识出Java程序中上百种潜在的不同类型的错误。

Checkstyle 它定义了一系列可用的模块,每一个模块提供了严格程度(强制的,可选的…)可配置的检查规则。规则可以触发通知(notification),警告(warning)和错误(error)。

 

现在有很多查看这些工具的处理结果的方式:

 

  • XML格式:这些工具都可以产生XML文件,这些XML文件能用来产生HTML报表或者是被别的工具用来浏览分析的结果。
  • HTML格式:HTML格式是最受欢迎的产生报表和团队间分享的的方式,你也可以用xsl表格创建你自己的报表。
  • IDE插件:几乎所有叫得上名字的IDE都给这些工具提供了插件,这使得发现源码中存在的所有问题几乎变成可能。

 

  代码质量工具的一个问题是,它们有时候会给开发者提示很多不是错误的错误-也叫做假阳性(false positives)。当这种情况发生的时候,开发者可以学着忽略工具的输出信息,或者是把这些输出全部抛弃掉。

 

  为了更好的利用这些工具的输出结果,给开发者一个更有用的视图,最好是有一种只关注我们想要的东西的方式。本文中,我们将找出其他有趣的方式来更好的利用所有这些有名的Java静态分析工具的输出结果,然后可以像查询数据库那样查询这些结果。

JArchitect和CQLinq

JArchitect是另一个静态分析工具,它弥补了其他工具(的不足),它是使用一种基于Linq(CQLinq)的代码查询语言像查询数据库那样来查询代码。

JArchitect3的以前版本,只能查询从JArchitect提取出来的分析数据,但是从JArchitect4开始,可以把许多其他静态分析工具的输出结果包含进来,然后使用CQLinq做查询。

这个是项目经理用来统计工作量的吧,哈哈。 

 

                                                     参考:如何更好地利用Pmd、Findbugs和CheckStyle分析结果

 

 

posted @ 2016-05-16 18:09  二郎那个三郎  阅读(407)  评论(0编辑  收藏  举报