Objective-C 错误处理


在 Objective-C 编程中,错误处理是由Foundation 框架中可用的 NSError 类提供的。

NSError 对象封装了比仅使用错误代码或错误字符串更丰富、更可扩展的错误信息。NSError 对象的核心属性是错误域(由字符串表示)、特定于域的错误代码和包含应用程序特定信息的用户信息字典。

NS错误

Objective-C 程序使用 NSError 对象来传达用户需要了解的运行时错误信息。在大多数情况下,程序会在对话框或工作表中显示此错误信息。但它也可能解释该信息并要求用户尝试从错误中恢复或尝试自行更正错误

NSError 对象包含 -

  • Domain - 错误域可以是预定义的 NSError 域之一,也可以是描述自定义域的任意字符串,并且域不能为零。

  • 代码- 错误的错误代码。

  • 用户信息- 错误的 userInfo 字典和 userInfo 可能为零。

以下示例展示了如何创建自定义错误

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