ios開發(fā)中的容錯處理示例詳解
前言
后臺服務(wù)器返回給客戶端的值有時會是null,有時會是"<null>",直接賦值并進行后續(xù)操作有時會導(dǎo)致崩潰。 之前的處理方式都是盡量讓后臺服務(wù)器返回數(shù)據(jù)時不返回null或者是"<null>",但是他們還是時不時返回這些數(shù)據(jù),所以app時不時就會出現(xiàn)閃退現(xiàn)象。一出現(xiàn)這種問題,調(diào)試后發(fā)現(xiàn)是他們返回null或者是"null"的數(shù)據(jù)類型,因為是線上的問題,所以讓他們直接在后臺將出現(xiàn)問題的字段進行處理就好了。久而久之,發(fā)現(xiàn)這種處理方式并不可取,覺得應(yīng)該在app端應(yīng)該做些容錯處理,因此就有了這篇文章,接下來和我看一下有哪些容錯處理的方式。
具體如下:
寫個工具類,判斷處理每個字段是不是[NSNull null]對象,或者判斷是不是isEqual:@"<null>";
用AFNetworking作為網(wǎng)絡(luò)請求的話,可以設(shè)置以下變量為YES;
// AFURLResponseSerialization.h /** Whether to remove keys with `NSNull` values from response JSON. Defaults to `NO`. */ @property (nonatomic, assign) BOOL removesKeysWithNullValues;
大牛寫了個NSNull分類:源碼地址 (本地下載)用法是直接將該類拖到項目中即可,NullSafe思路:在運行時操作,把空值置換為nil,而向nil指針發(fā)送消息是不會崩潰的。
我這里主要說的是第三種解決方案,我將該項目從github上下載到本地,然后拖到項目中后,本以為這樣就可以解決問題了,因為自己寫了個測試demo,給UILabel賦值null,沒有拖進去該庫時直接崩潰了,將該庫拖進項目后發(fā)現(xiàn)項目正常運行。所以就認為可以一勞永逸了,但是在項目中測試時,發(fā)現(xiàn)仍然出現(xiàn)崩潰的現(xiàn)象,打斷點調(diào)試后,發(fā)現(xiàn)后臺傳回的數(shù)據(jù)是"<null>",而NSNull分類中只是判斷了數(shù)據(jù)是否是NSNull類型,如果是NSNull類型,就將其設(shè)置為nil,然而后臺傳回的數(shù)據(jù)是"<null>",它并不是NSNull類型,所以仍然會崩潰,所以我在該項目的基礎(chǔ)上,加了個是否等于<null>的判斷,如果條件成立,則將其設(shè)置為nil,這樣就可以避免后臺傳回我們不想要的數(shù)據(jù)而導(dǎo)致崩潰的問題了,修改后的代碼如下:
- (NSMethodSignature *)methodSignatureForSelector:(SEL)selector { //look up method signature NSMethodSignature *signature = [super methodSignatureForSelector:selector]; if ([signature isEqual:@"<null>"]) { signature = nil; }else if ([signature isKindOfClass:[NSNull class]]) { signature = nil; }else if (!signature) { //check implementation cache first NSString *selectorString = NSStringFromSelector(selector); signature = signatureCache[selectorString]; if (!signature) { @synchronized([NSNull class]) { //check again, in case it was resolved while we were waitimg signature = signatureCache[selectorString]; if (!signature) { //not supported by NSNull, search other classes if (signatureCache == nil) { if ([NSThread isMainThread]) { cacheSignatures(); } else { dispatch_sync(dispatch_get_main_queue(), ^{ cacheSignatures(); }); } } //find implementation for (Class someClass in classList) { if ([someClass instancesRespondToSelector:selector]) { signature = [someClass instanceMethodSignatureForSelector:selector]; break; } } //cache for next time signatureCache[selectorString] = signature ?: [NSNull null]; } } } } return signature; }
當(dāng)然也可以去github下載,源碼地址 (本地下載),但是需要加上下圖所示的代碼:
需要添加的代碼截圖
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。
相關(guān)文章
iOS實現(xiàn)頂部標(biāo)簽式導(dǎo)航欄及下拉分類菜單
這篇文章主要為大家詳細介紹了iOS實現(xiàn)頂部標(biāo)簽式導(dǎo)航欄及下拉分類菜單的相關(guān)資料,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2016-03-03詳解IOS判斷當(dāng)前網(wǎng)絡(luò)狀態(tài)的三種方法
這篇文章主要介紹了詳解IOS判斷當(dāng)前網(wǎng)絡(luò)狀態(tài)的三種方法,網(wǎng)絡(luò)狀態(tài)是非常重要的知識,感興趣的同學(xué),必須要看一下2021-04-04總結(jié)iOS App開發(fā)中控制屏幕旋轉(zhuǎn)的幾種方式
這篇文章主要介紹了iOS app開發(fā)中控制屏幕旋轉(zhuǎn)的方法總結(jié),分為自動旋轉(zhuǎn)和手動旋轉(zhuǎn)以及強制旋轉(zhuǎn)三種情況,代碼為Objective-C語言,需要的朋友可以參考下2016-02-02IOS開發(fā)代碼分享之用nstimer實現(xiàn)倒計時功能
在制作IOS項目中,我們經(jīng)常要用到倒計時功能,今天就分享下使用nstimer實現(xiàn)的倒計時功能的代碼,希望對大家能有所幫助2014-09-09