态检查一般是检查编码标准规范,错误列表。编码规范往往团队
会根据自己的经验和风格进行设置一些规范。现在很多IDE工具都会
在编辑代码的时候实时的提醒是否符合代码风格。错误列表,一般
是代码潜在的bug,由于某种代码写法虽然没有语法错误,但是可能
存在错误,比如会导致线程死锁。这些都是错误列表应该检查的。
静态检查的可操作方式
1、代码走查
程序员之间可以隔一定的时间抽取代码进行走查。
走查的时候根据汇总报告,把这些经验汇成列表,作为下次代码走查的依据。
该方式的特点是,手工、多人讨论、操作简单,但是效率会比较低。
2、代码扫描
使用软件对我们的代码进行扫描,查找出潜在的问题。现在有许多商业的
工具能够进行扫描,比如Parasoft JTest、Rational® Software Analyzer、
pclint等工具,往往不同的工具会针对不同的语言。当然也有很多开源的工
具。在这里java方面主要推荐Findbugs。Findbugs可以在ANT/GUI/ECLIPSE三个
环境中运行,同时也可以编写自己的检测器,功能比较完善。我们平时可以收
集自己的或者是别人的开发经验,把它做成检测器来完善Findbugs的检测体系。
软件扫描的特点是,机器扫描、效率高,但是没不够灵活,扩展比较负责。
经过不少时间的分析,最后是我们选择了Findbugs作为静态检查工具。以后
将以此为突破口,进行该项工作。下面简单介绍该工具。
Findbugs是一个在java程序中查找bug的程序,它查找bug模式的实例,
也就是可能出错的代码实例,注意Findbugs是检查java字节码,也就
是*.class文件。其实准确的说,它是寻找代码缺陷的,很多我们写
的不好的地方,可以优化的地方,它都能检查出来。例如:未关闭的数
据库连接,缺少必要的null check,多余的 null check,多余的if后置
条件,相同的条件分支,重复的代码块,错误的使用了"==",建议使用
StringBuffer代替字符串连加等等。而且我们还可以自己配置检查规
则(做哪些检查,不做哪些检查),也可以自己来实现独有的校验规
则(用户自定义特定的bug模式需要继承它的接口,编写自己的校验类,属于高级技巧)。
Findbugs是一个静态分析工具,它检查类或者JAR 文件,将字节码与一组
缺陷模式进行对比以发现可能的问题。Findbugs自带检测器,其中有
60余种Bad practice,80余种Correctness,
1种 Internationalization,
12种Malicious code vulnerability,
27种Multithreaded correctness,
23种Performance,
43种Dodgy。
--------------------------------------------------river.liu 2010.3.30
javascript代码静态检查工具 代码静态测试方法
转载本文章为转载内容,我们尊重原作者对文章享有的著作权。如有内容错误或侵权问题,欢迎原作者联系我们进行内容更正或删除文章。
提问和评论都可以,用心的回复会被更多人看到
评论
发布评论
相关文章
-
静态代码检查工具 FindBugs
使用 FindBugs的原因和方法 静态分析工具承诺无需开发人
eclipse jar java