1.什么是FindBugs
一句話(huà)簡(jiǎn)單理解就是:是一個(gè)工具需了,可以用它自動(dòng)幫你找出代碼中潛在的BUG。當(dāng)然事實(shí)并不一定總是如此,也有很多它找不出來(lái)的地方猜绣。下面將直接介紹如何在Android Studio中的簡(jiǎn)單使用蹄衷。有興趣的童鞋可以自己去了解了解逮矛,附上官網(wǎng)窑滞。
2.在Android Studio中使用FindBugs-IDEA插件
(1)安裝插件
Android Studio --> File --> Settings... --> Plugins --> 搜索FindBugs-IDEA --> 安裝并重啟Android Studio
重啟之后可以看見(jiàn)Android Studio窗口下方的工具欄中出現(xiàn)了一個(gè)新的選項(xiàng),如下圖:
(2)工具欄說(shuō)明
上圖所說(shuō)的選項(xiàng)點(diǎn)開(kāi)之后的樣子和下面一樣(我的工程名字叫:MyApplication):
紅框中的圖標(biāo)會(huì)根據(jù)你當(dāng)前選中的文件或文件夾电爹,有不同情況的亮滅蔫仙,即是否可點(diǎn)擊狀態(tài)(圖中是我的光標(biāo)停留在一個(gè)java文件中時(shí)的狀態(tài)),鼠標(biāo)停留在圖標(biāo)上一會(huì)兒會(huì)有圖標(biāo)說(shuō)明出現(xiàn)丐箩。
(3)使用演示
首先摇邦,在File --> Settings... --> FindBugs-IDEA --> Filter中添加忽略檢查的文件(一般是忽略.R和Manifest,不忽略這兩個(gè)文件的話(huà)可能會(huì)檢查出一些所謂的BUG屎勘,但你并不能修復(fù)它們)施籍,如下圖所示:
其中文件"findbugs-android-exclude.xml"打開(kāi)后如下,復(fù)制保存為xml格式后在中間紅框處選擇添加它:
<?xml version="1.0" encoding="UTF-8"?>
<FindBugsFilter>
<!-- http://stackoverflow.com/questions/7568579/eclipsefindbugs-exclude-filter-files-doesnt-work -->
<Match>
<Or>
<Class name="~.*\.R\$.*"/>
<Class name="~.*\.Manifest\$.*"/>
</Or>
</Match>
</FindBugsFilter>
添加完成之后選擇OK概漱,即可開(kāi)始使用(當(dāng)然你也可以添加其它不想被檢測(cè)的文件)丑慎。
使用
檢查的功能很全面,比如檢查當(dāng)前選中文件瓤摧、檢查文件夾竿裂、檢查整個(gè)工程等等。
這里只寫(xiě)出最簡(jiǎn)單也是最常用的方式——檢查當(dāng)前選中文件照弥,其它方式各位可自己多試試就明白了腻异。
我先在MainActivity中寫(xiě)一個(gè)死循環(huán),如下圖所示:
然后在左邊文件樹(shù)中選中MainActivity.java這個(gè)文件这揣,打開(kāi)下方工具欄中的FindBugs-IDEA悔常,點(diǎn)擊第一列中紅色那只蟲(chóng)(或者直接使用快捷鍵Ctrl+Alt+Shift+F)敢会,之后就開(kāi)始檢測(cè)了,檢測(cè)完后这嚣,會(huì)顯示出有BUG的代碼在什么位置,還有一些說(shuō)明塞俱,如下圖:
點(diǎn)擊藍(lán)色的那條姐帚,窗口就會(huì)跳到有BUG的代碼處,修改好之后再重新運(yùn)行檢測(cè)就行了障涯。
最后
總的來(lái)說(shuō)罐旗,這個(gè)工具還是很方便的,通常情況下可以檢查出以下幾類(lèi)問(wèn)題:
1) Bad practice:不好的做法唯蝶,代碼違反了公認(rèn)的最佳實(shí)踐標(biāo)準(zhǔn)九秀,比如某個(gè)類(lèi)實(shí)現(xiàn)了equals方法但未實(shí)現(xiàn)hashCode方法等;
2)Malicious code vulnerbility:惡意的代碼漏洞粘我;
3)Correctness:可能不正確鼓蜒,比如錯(cuò)誤的強(qiáng)制類(lèi)型轉(zhuǎn)換;
4)Performance:潛在的性能問(wèn)題征字;
5)Security:安全性都弹;
6)Dodgy code:糟糕的代碼,F(xiàn)indBugs團(tuán)隊(duì)認(rèn)為該類(lèi)型下的問(wèn)題代碼導(dǎo)bug的可能性很高匙姜;
7)Experimental:實(shí)驗(yàn)畅厢;
8)Multithreaded correctness:關(guān)注于同步和多線(xiàn)程問(wèn)題;
9)Internationalization:國(guó)際化
不過(guò)氮昧,關(guān)于業(yè)務(wù)方面的BUG框杜,它可就無(wú)能為力了。
原文作者/ZYRzyr
原文鏈接:http://www.reibang.com/p/adc5e7f9f9fb
請(qǐng)進(jìn)入這里獲取授權(quán):https://101709080007647.bqy.mobi