使用Infer進(jìn)行靜態(tài)代碼掃描

安裝Infer

在Mac上可以直接使用brew 來安裝,比較簡單

brew install infer 

使用Infer

  • Android
infer -- gradle build
  • iOS
cd 到你的當(dāng)前工程目錄下
# 普通工程
infer run -- xcodebuild -target xxx -scheme xxx -configuration Debug -sdk iphonesimulator
# pod工程
infer run -- xcodebuild -workspace xxx.xcworkspace -scheme xxx -configuration Debug -sdk iphonesimulator

查看報(bào)告

腳本跑完之后在 infer-out/bugs.txt查看結(jié)果

出現(xiàn)常見錯(cuò)誤類型有:

NULL_DEREFERENCE:空指針的情況喳瓣。

1.傳參為0的情況下阁危。例如代碼中哲身,在調(diào)用showAlertViewA()時(shí),將tag傳參為0,infer檢測(cè)此處傳0,判斷為一個(gè)NULL空指針订讼,所以爆出警告纵装。這里可以理解為誤報(bào)征讲,不會(huì)出現(xiàn)問題。
2.通過malloc,calloc,realloc等函數(shù)申請(qǐng)內(nèi)存橡娄,當(dāng)內(nèi)存不足時(shí)诗箍,有可能會(huì)在該函數(shù)中返回NULL,如果沒有做NULL的判斷挽唉,則警告
3.在創(chuàng)建NSArray或者NSDictionary時(shí)滤祖,傳入的參數(shù)有可能會(huì)nil才避。由于NSArray與NSDictionary不接受空指針,所以在對(duì)其addObject或者setObject:forKey: 時(shí)需要進(jìn)行判斷一下是否為nil

MEMORY_LEAK:內(nèi)存泄漏:

項(xiàng)目代碼全面啟動(dòng)了ARC進(jìn)行內(nèi)存管理氨距,在OC層沒有掃描出內(nèi)存泄露桑逝。目前掃描出的內(nèi)存泄露問題都是使用了malloc或者ralloc等c語言內(nèi)存申請(qǐng)函數(shù),在函數(shù)提前return前沒有及時(shí)free

RESOURCE_LEAK:資源泄漏
ASSIGN_POINTER_WARNING

由于在mrc時(shí)代俏让,沒有weak指針楞遏,所以一些view的屬性聲明是、unsafe__unretain_的形式首昔,在arc中寡喝,這個(gè)屬性被判斷為assign,需要將其修改為weak或者strong

DIRECT_ATOMIC_PROPERTY_ACCESS

在代碼中使用了使用了一個(gè)atomic的成員變量勒奇,infer建議我們將atomic修改為nonatomic预鬓。由于OC中,屬性會(huì)被默認(rèn)設(shè)置為atomic屬性赊颠,我們需要顯示將屬性聲明為nonatomic格二。

IVAR_NOT_NULL_CHECKED

在代碼中調(diào)用block,運(yùn)行代碼時(shí)竣蹦,沒有做判空處理顶猜。即需要改動(dòng)為,if(block){block()}

BAD_POINTER_COMPARISON

沒有判斷一個(gè)NSNumber類型的對(duì)象是不是空痘括?

TAINTED_VALUE_REACHING_SENSITIVE_FUNCTION

代碼中使用了cookie的value长窄。可以理解為誤報(bào)

PARAMETER_NOT_NULL_CHECKED

傳參時(shí)沒有判斷是否為null纲菌,加一次判斷就可以了

STRONG_DELEGATE_WARNING

將一個(gè)delegate屬性設(shè)置為strong的類型挠日。

PREMATURE_NIL_TERMINATION_ARGUMENT

沒有判斷是否為空

REGISTERED_OBSERVER_BEING_DEALLOCATED

創(chuàng)建一個(gè)對(duì)象后,監(jiān)聽了某些通知翰舌,但是沒有在dealloc中釋放該通知嚣潜。項(xiàng)目中出現(xiàn)這種問題的類,基本都是單例灶芝,不會(huì)被銷毀郑原。

參考文檔:
使用 Infer 進(jìn)行代碼掃描
iOS開發(fā)之使用 infer靜態(tài)代碼掃描工具

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市夜涕,隨后出現(xiàn)的幾起案子犯犁,更是在濱河造成了極大的恐慌,老刑警劉巖女器,帶你破解...
    沈念sama閱讀 222,729評(píng)論 6 517
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件酸役,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)涣澡,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 95,226評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門贱呐,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人入桂,你說我怎么就攤上這事奄薇。” “怎么了抗愁?”我有些...
    開封第一講書人閱讀 169,461評(píng)論 0 362
  • 文/不壞的土叔 我叫張陵馁蒂,是天一觀的道長。 經(jīng)常有香客問我蜘腌,道長沫屡,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 60,135評(píng)論 1 300
  • 正文 為了忘掉前任撮珠,我火速辦了婚禮沮脖,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘芯急。我一直安慰自己勺届,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 69,130評(píng)論 6 398
  • 文/花漫 我一把揭開白布志于。 她就那樣靜靜地躺著涮因,像睡著了一般。 火紅的嫁衣襯著肌膚如雪伺绽。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 52,736評(píng)論 1 312
  • 那天嗜湃,我揣著相機(jī)與錄音奈应,去河邊找鬼。 笑死购披,一個(gè)胖子當(dāng)著我的面吹牛杖挣,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播刚陡,決...
    沈念sama閱讀 41,179評(píng)論 3 422
  • 文/蒼蘭香墨 我猛地睜開眼惩妇,長吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來了筐乳?” 一聲冷哼從身側(cè)響起歌殃,我...
    開封第一講書人閱讀 40,124評(píng)論 0 277
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎蝙云,沒想到半個(gè)月后氓皱,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 46,657評(píng)論 1 320
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,723評(píng)論 3 342
  • 正文 我和宋清朗相戀三年波材,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了股淡。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,872評(píng)論 1 353
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡廷区,死狀恐怖唯灵,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情隙轻,我是刑警寧澤埠帕,帶...
    沈念sama閱讀 36,533評(píng)論 5 351
  • 正文 年R本政府宣布,位于F島的核電站大脉,受9級(jí)特大地震影響搞监,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜镰矿,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 42,213評(píng)論 3 336
  • 文/蒙蒙 一琐驴、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧秤标,春花似錦绝淡、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,700評(píng)論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至衙猪,卻和暖如春馍乙,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背垫释。 一陣腳步聲響...
    開封第一講書人閱讀 33,819評(píng)論 1 274
  • 我被黑心中介騙來泰國打工丝格, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人棵譬。 一個(gè)月前我還...
    沈念sama閱讀 49,304評(píng)論 3 379
  • 正文 我出身青樓显蝌,卻偏偏與公主長得像,于是被迫代替她去往敵國和親订咸。 傳聞我的和親對(duì)象是個(gè)殘疾皇子曼尊,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,876評(píng)論 2 361