博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Android 静态代码分析工具
阅读量:6713 次
发布时间:2019-06-25

本文共 2737 字,大约阅读时间需要 9 分钟。

hot3.png

简评: 作者在文中提到的三个静态代码分析工具不是互相替代的关系,各有各的侧重点,如果有需要完全可以同时使用。

静态代码分析是指无需运行被测代码,仅通过分析或检查源程序的语法、结构、过程、接口等来检查程序的正确性,找出代码隐藏的错误和缺陷,如参数不匹配,有歧义的嵌套语句,错误的递归,非法计算,可能出现的空指针引用等等。

对于 Android 来说用得最多的三个静态代码分析工具当属:

  • Lint
  • PMD
  • Findbugs

Lint

Lint 是 Google 提供给 Android 开发者的静态代码分析工具,能帮助开发者优化代码和找到潜在的 bug。

配置:

在项目中创建 文件:

android {    lintOptions {        lintConfig file("$project.rootDir/tools/rules-lint.xml")        htmlOutput file("$project.buildDir/outputs/lint/lint.html")        warningsAsErrors true        xmlReport false    }}

其中两个重要的属性:

  • lintConfig : lint 规则文件的路径。
  • htmlOutput : html 报告生成的路径。

之后在 build.gradle 文件中引用:

apply plugin: 'com.android.application'apply from: "$project.rootDir/tools/script-lint.gradle"...

测试:

运行 ./gradlew lint 命令,就可以在上面设置的 htmlOutput 路径下找到 lint.html 文件,打开后就会看到类似下面的提示: 提示

Findbugs

Findbugs 分析的是 Java 字节码,能识别出上百种的潜在错误。

配置:

创建 文件:

apply plugin: 'findbugs'task findbugs(type: FindBugs) {    excludeFilter = file("$project.rootDir/tools/rules-findbugs.xml")    classes = fileTree("$project.buildDir/intermediates/classes/dev/debug/com/dd")    source = fileTree("$project.rootDir/src/main/java/com/dd/")    classpath = files()    reports {        xml.enabled = false        html.enabled = true        html.destination = "$project.buildDir/outputs/findbugs/findbugs.html"    }}

属性:

  • excludeFilter:Findbugs 规则文件的路径。
  • classes:classes 文件的路径。
  • source:源码的路径。
  • html.destination:html 报告的生成地址。

同样需要在 build.gradle 中进行引用:

apply plugin: 'com.android.application'apply from: "$project.rootDir/tools/script-findbugs.gradle"...

测试:

下面的这段代码:

// MainActivity.java...private void someMethod(int variable) {   switch (variable) {       case 1:           System.out.println("1");       case 2:           System.out.println("2");   }}...

运行./gradlew findbugs命令,findbugs.html 中就会生成检测结果,类似于下面这样: 检测结果

##PMD

PMD 能发现常见的编程缺陷,比如未使用的变量、空的 catch 块、不必要的对象等等。

配置:

创建 文件:

apply plugin: 'pmd'task pmd(type: Pmd) {    ruleSetFiles = files("$project.rootDir/tools/rules-pmd.xml")    source = fileTree('src/main/java/')    reports {        xml.enabled = false        html.enabled = true        html.destination = "$project.buildDir/outputs/pmd/pmd.html"    }}

属性:

  • ruleSetFiles:规则文件路径。
  • source:源码路径。
  • html.destination:检测结果的 html 文件所在路径。

同样,再在 build.gradle 文件中引用:

apply plugin: 'com.android.application'apply from: "$project.rootDir/tools/script-pmd.gradle"...

测试:

// MainActivity.java...private void someMethod(int a, int b, int c, int d) {   if (a > b) {       if (b > c) {           if (c > d) {               if (d > a) {                   // some logic               }           }       }   }}...

执行 ./gradlew pmd 命令,在 html.destination 设置的路径下找到 pmd.html,就能够看到如下的检测结果: 检测结果

上面提到的所有文件,和配置项都可以在作者的这个项目中找到:


原文链接: 推荐阅读

欢迎关注微信号「极光开发者」,不定期赠书活动!

转载于:https://my.oschina.net/jpushtech/blog/3048845

你可能感兴趣的文章
Nginx+Keepalived实现
查看>>
安装python的easy_install和pip
查看>>
android SQLite
查看>>
Apache for Load Banlance
查看>>
Sublime Text 2 快捷键用法大全
查看>>
放弃redis使用mongodb做任务队列支持增删改管理
查看>>
20几岁要懂的处世心理学
查看>>
G口与S口的区别
查看>>
linux xen安装
查看>>
apache2.4.16 显示真实ip
查看>>
甲骨文拒绝SAP 2.72亿美元赔偿要求重审
查看>>
Springmvc中@ResponseBody和@RequestBody的使用
查看>>
H3C设备之 NAT SERVER
查看>>
FLEX3中应用CSS完全详解手册
查看>>
Windows7添加usb3.0驱动
查看>>
模式——工程化实现及扩展(设计模式Java 版)
查看>>
如何干净的清除Slave同步信息
查看>>
Oracle动态采样学习
查看>>
借助开源工具高效完成Java应用的运行分析
查看>>
Transparent Huge Pages相关概念
查看>>