NSNumber進行比較出現(xiàn)nil,造成的crash
場景再現(xiàn):上線后出現(xiàn)大量crash,crash發(fā)生在iOS8和iOS9設(shè)備中。同一設(shè)備多次請求,造成crash率暴增。
問題解決:經(jīng)過測試發(fā)現(xiàn),在nsnumber的比較方法中,從接口中獲得數(shù)據(jù),然后和本地緩存數(shù)據(jù)進行比較,這個時候老版本沒有相應(yīng)的字段,iOS8和iOS9設(shè)備的Coredata將這種數(shù)據(jù)直接置為nil而沒有設(shè)置為0,而isEqualToNumber在后面的參數(shù)為空時,可能crash。這就造成用戶升級后出現(xiàn)crash,這個時候緊急關(guān)閉升級通道,減少老用戶升級后的crash。
總結(jié)教訓(xùn):1.接口升級時,一定考慮新老用戶的兼容問題,以及本地數(shù)據(jù)緩存為空的情況。2.一方面,增加相應(yīng)的方法,進行預(yù)先判斷,防止對nil進行比較;另一方面,利用運行時動態(tài)更改isEqualToNumber方法,拋出crash問題。3.老系統(tǒng)一定要做兼容性測試。