Objective-C 錯誤處理
在Objective-C編程,錯誤處理提供由Foundation框架的 NSError類。
一個的NSError對象封裝更加豐富和擴展的錯誤信息,可能比隻使用一個錯誤代碼或錯誤字符串。 NSError對象的核心屬性是一個錯誤域(由一個字符串表示),域特定的錯誤代碼和用戶信息字典,包含應用程序的具體信息。
NSError
Objective-C程序使用NSError對象運行時錯誤,用戶需要了解的信息傳達。在大多數情況下,程序會顯示一個對話框,這個錯誤信息或片狀。但它也可能解釋的信息,或者詢問用戶來嘗試恢複錯誤或嘗試糾正該錯誤在其自己
NSError對象包括:
-
域名:錯誤域可以是一個預定義的的NSError域或任意字符串描述一個自定義域和域必須為nil。
-
代碼:錯誤的錯誤代碼。
-
用戶信息:用戶信息字典錯誤和 userInfo 可能為 nil.
下麵的例子演示了如何創建一個自定義的錯誤
NSString *domain = @"com.MyCompany.MyApplication.ErrorDomain"; NSString *desc = NSLocalizedString(@"Unable to complete the process", @""); NSDictionary *userInfo = @{ NSLocalizedDescriptionKey : desc }; NSError *error = [NSError errorWithDomain:domain code:-101 userInfo:userInfo];
下麵是完整的代碼通過上述錯誤樣本作為參考指針
#import <Foundation/Foundation.h> @interface SampleClass:NSObject -(NSString *) getEmployeeNameForID:(int) id withError:(NSError **)errorPtr; @end @implementation SampleClass -(NSString *) getEmployeeNameForID:(int) id withError:(NSError **)errorPtr{ if(id == 1) { return @"Employee Test Name"; } else { NSString *domain = @"com.MyCompany.MyApplication.ErrorDomain"; NSString *desc =@"Unable to complete the process"; NSDictionary *userInfo = [[NSDictionary alloc] initWithObjectsAndKeys:desc, @"NSLocalizedDescriptionKey",NULL]; *errorPtr = [NSError errorWithDomain:domain code:-101 userInfo:userInfo]; return @""; } } @end int main() { NSAutoreleasePool * pool = [[NSAutoreleasePool alloc] init]; SampleClass *sampleClass = [[SampleClass alloc]init]; NSError *error = nil; NSString *name1 = [sampleClass getEmployeeNameForID:1 withError:&error]; if(error) { NSLog(@"Error finding Name1: %@",error); } else { NSLog(@"Name1: %@",name1); } error = nil; NSString *name2 = [sampleClass getEmployeeNameForID:2 withError:&error]; if(error) { NSLog(@"Error finding Name2: %@",error); } else { NSLog(@"Name2: %@",name2); } [pool drain]; return 0; }
在上麵的例子中,我們返回一個名稱,如果ID為1,否則,我們設置用戶定義的錯誤對象。
上麵的代碼編譯和執行時,它會產生以下結果:
2013-09-14 18:01:00.809 demo[27632] Name1: Employee Test Name 2013-09-14 18:01:00.809 demo[27632] Error finding Name2: Unable to complete the process