• 使用FindBugs-IDEA插件找到代码中潜在的问题


    另一篇使用文档,参照:https://www.cnblogs.com/huaxingtianxia/p/6703315.html

    我们通常都会在APP上线之后,发现各种错误,尤其是空指针异常,这些错误对于用户体验来说是非常不好的,但其实大部分的问题,我们都能够提前发现.

    在编写代码的过程中,可能不会时时刻刻记得检查空的引用,还有删除没有用过的变量,在我们自己测试的过程中可能难以发现问题,一旦app上线,用户的使用环境改变,这些潜在的问题就可能会冒出来. 
    当然这这只是对于我这种经常写出空指针异常的小白而言的,编程风格良好,编程严谨的大神请忽略.

    今天我介绍一个小插件,帮助我们提前找到这些潜在的问题,然后根据需要去修改.

    第一步下载插件,在AndroidStudio的File->Setting->Plugins->Browser Repositorise中搜索FindBugs-IDEA.然后install. 
    install-plugin
    因为已经安装过插件,所以install的按钮已经消失了. 
    安装成功后需要重启AS才可以使用. 
    use-plugin 
    静静等待一会,在下方生成分析结果

    这里写图片描述

    找到的bug太多,数量就不展示啦. 
    我来简单介绍一下这几类bug,当然有些你是可以忽略的. 
    1->Bad pratice编程的坏习惯 
    主要是命名问题,比如类名最好以大写开头,字符串不要使用等号不等号进行比较,可能会有异常最好用try-catch包裹的代码,方法有返回值但被忽略等等,这些如果不想改可以直接忽略.

    2->Malicious code vulnerability 恶意代码漏洞 
    听起来很吓人呀,主要是一些属性直接使用public让别的类来获取,建议改为private并为其提供get/set方法. 
    还有一些public的静态字段,可能会被别的包获取之类的. 
    这些也需要根据项目具体情况来,个人意见,在有的不重要类,有时直接公开使用属性,可能更为便捷.如果你认为这些不需要修改,完全可以忽略.

    3->Dodgy code 糟糕的代码 
    ·比如一个double/float被强制转换成int/long可能会导致精度损失,一些接近零的浮点数会被直接截断,事实上我们应该保留. 
    这里顺便提一点,这两天看了《app研发录》,在规范代码,尽量规避错误这方面我也有了一些收获. 
    在类型转换的时候,我们应该为类型转换提供一个安全的转换方法,因为我们永远不会知道,我们的app在用户手里会发生什么,所以我们要尽可能的去减少这种发生错误的可能.

    ·比如使用switch的时候没有提供default。

    ·多余的空检查,就是不可能为空的值,增加了不为空判断,这是没有必要的。属于代码冗余

    ·不安全的类型转换等等。 
    这项太多了,就不一一列举了。

    4->performance 性能 
    主要是一些无用的代码,比如声明了没有用到的属性等等

    5->correctness 代码的正确性 这一项应该算是最重要的了 
    主要是没有对变量进行不为空判定,在特殊情况可能发生空指针异常.

    这篇文章还只是对FindBugs这个插件最主要的功能进行介绍,相信你能在使用过程中发现这个工具更多的用法.

    该博客由博主原创,转载请声明出处 
    http://blog.csdn.net/fancy_xty/article/details/51718687

  • 相关阅读:
    bzoj4537: [Hnoi2016]最小公倍数
    bzoj4331: JSOI2012 越狱老虎桥
    bzoj4558: [JLoi2016]方
    bzoj4209: 西瓜王
    bzoj2653: middle
    bzoj4671: 异或图
    bzoj4771: 七彩树
    shell java应用启动脚本(app.sh)
    Springboot 构建http服务,返回的http行是'HTTP/1.1 200' 无状态码描述 客户端解析错误
    MariaDB(Mysql)-主从搭建
  • 原文地址:https://www.cnblogs.com/aligege/p/7308274.html
Copyright © 2020-2023  润新知