以为本身代码写得不够好?那就用 Android 代码优化工具吧~

1.前言:

在咱们平时项目开发中,常常会写一些不严谨的代码或者一些比较低级的错误代码,可是这些错误每每很难被发现,这样就致使了咱们的项目中会隐藏了不少影响性能甚至是致使闪退的错误代码,因而许多响应的检测工具就出现了.在这里我就介绍一下我比较经常使用的几个检测工具吧javascript

项目DEMO源码

2.FindBugs

顾名思义,FindBugs是一个寻找bug的工具,更具体的说FindBugs是一个静态检测java代码的工具,能够找到代码中的一些潜在bug,好比说NullPointerException,或者是一些流或者数据库没有关闭的问题.html

2.1做用

检测范围 :java

  • 常见代码错误,序列化错误
  • 可能致使错误的代码,如空指针引用
  • 国际化相关问题:如错误的字符串转换
  • 可能受到的恶意攻击,如访问权限修饰符的定义等
  • 多线程的正确性:如多线程编程时常见的同步,线程调度问题。
  • 运行时性能问题:如由变量定义,方法调用致使的代码低效问题

    2.2使用方法

    FindBugs在Android studio里面有个插件 正常安装便可(不会安装插件的本身google)

安装好插件以后重启一下Android studio,在底部会有个红色的图标(不一样版本可能位置不一样),若是你出现了这个图标,那么恭喜你完成了第一步

点击左侧第五个按钮能够开始检测

检测结果显示以下
  • 当建立流的时候发生了异常 那么inputStream就可能为空 接下来直接调用inputStream就可能产生空指针异常
    android

  • 这里使用了io流,可是没有作释放
    git

2.3设置

在setting里面还能够对FindBugs作一些设置(这里就不作详细的介绍了)

2.4自定义规则

FindBugs能够在gradle里面作自定义任务
(注意须要在gradle里面添加 apply plugin:'findbugs')


在这里配置了规则findbugs-filter.xml 以及报告生成的路径findbugs.xml
task findbugs(type: FindBugs, dependsOn: "assembleDebug") {
    ignoreFailures = false
    effort = "max"
    reportLevel = "high"
    excludeFilter = new File("$configDir/findbugs/findbugs-filter.xml")//这里是自定义的规则
    classes = files("${project.rootDir}/app/build/intermediates/classes")

    source 'src'
    include '**/*.java'
    exclude '**/gen/**'

    reports {
        xml.enabled = false
        html.enabled = true
        xml {
            destination "$reportsDir/findbugs/findbugs.xml"  //这里是报告产生的路径
        }
        html {
            destination "$reportsDir/findbugs/findbugs.html"  //这里是报告产生的路径
        }
    }

    classpath = files()
}复制代码
运行自定义任务(找到任务,双击便可)

3.PMD

PMD和FindBugs的做用差很少,可是他们俩的检测方法不一样,因此同时使用能达到互补.

3.1做用

检测范围 :
  • 可能的bug——空的try/catch/finally/switch块。
  • 无用代码(Dead code):无用的本地变量,方法参数和私有方法。
  • 空的if/while语句。
  • 过分复杂的表达式——没必要要的if语句,原本能够用while循环可是却用了for循环。
  • 可优化的代码:浪费性能的String/StringBuffer的使用。

3.2使用方法

PMD在Android studio也有个插件,直接安装便可(注意搜索的关键字用QAPlug - PMD)

3.3自定义规则

(注意须要在gradle里面添加 apply plugin: 'pmd')

task pmd(type: Pmd) {
    ignoreFailures = false
    ruleSetFiles = files("$configDir/pmd/pmd-ruleset.xml") //这里是自定义的规则
    ruleSets = []

    source 'src'
    include '**/*.java'
    exclude '**/gen/**'

    reports {
        xml.enabled = false
        html.enabled = true
        xml {
            destination "$reportsDir/pmd/pmd.xml"  //这里是报告产生的路径
        }
        html {
            destination "$reportsDir/pmd/pmd.html"  //这里是报告产生的路径
        }
    }
}复制代码
在这里配置了规则pmd-ruleset.xml 以及报告生成的路径 pmd.html

运行自定义任务(跟FindBugs同样,找到任务,双击便可)

4.CheckStyles

CheckStyles是用来检测java代码规范性的

4.1做用

检测范围 :
  • 注解
  • javadoc注释
  • 命名规范
  • 文件头
  • 导入包规范
  • 尺寸设置
  • 空格
  • 正则表达式
  • 修饰符
  • 代码块
  • 编码问题
  • 类设计问题
  • 重复、度量以及一些杂项

4.2使用方法

安装插件 CheckStyles

4.3设置

TreatCheckstyle errors as warnings 若是勾上的话,检测到错误时只是会以警告的形式提示github

下面是勾上时的提示方式(以警告的形式)正则表达式

下面是不勾时的提示方式(以报错的形式)
数据库

下面是选择官方默认的检测规则(也能够本身定义,具体这里就不作详解了)
编程

4.4经过gradle运行

(注意须要在gradle里面添加 apply plugin: 'checkstyle')

task checkstyle(type: Checkstyle) {
    configFile file("$configDir/checkstyle/checkstyle.xml") //这里是自定义的规则
    configProperties.checkstyleSuppressionsPath = file("$configDir/checkstyle/suppressions.xml").absolutePath  //这里是自定义的规则
    source 'src'
    include '**/*.java'
    exclude '**/gen/**'
    classpath = files()
}复制代码

5.Demo源码

Demo连接

github.com/yulyu2008/Q…

注意Demo里面的task都抽取到了config目录下的quality.gradle中,因此须要在项目的build.gradle添加android-studio

apply from: '../config/quality.gradle'

Demo是在他人的基础上修改的,因为已经没法找到源头,因此在这里声明一下

热门文章

相关文章
相关标签/搜索