虽然在实际编程中NSException运用不多,但也不妨碍了解一下Cocoa异常编程。
异常处理是管理非典型事件(例如未被识别的消息)的过程,此过程将会中断正常的程序执行。如果没有足够的错误处理,遇到非典型事件时,程序可能立刻抛出(或者引发)一种被称之为异常的东西,然后结束运行。
异常的类型
程序抛出异常的原因多种多样,可由硬件导致也可由软件引起。异常的例子很多,包括被零除、下溢和上异之类的数学错误,调用未定义的指令(例如,试图调用一个没有定义的方法 )以及试图越界访问群体中的元素 。
Cocoa异常由NSException对象作为载体,下面是NSException的声明:
1 @interface NSException : NSObject <NSCopying, NSCoding> { 2 @private 3 NSString *name; 4 NSString *reason; 5 NSDictionary *userInfo; 6 id reserved; 7 }
-
A
name
— a short string that is used to uniquely identify the exception. The name is required. -
A
reason
— a longer string that contains a “human-readable” reason for the exception. The reason is required. -
An optional dictionary (
userInfo
) used to supply application-specific data to the exception handler. For example, if the return value of a method causes an exception to be raised, you could pass the return value to the exception handler throughuserInfo
.
你可以在异常捕获后提取有用的信息,还可以适当的弹出一个异常警告框。
抛出的异常必须是NSException或者其子类,不能是其他类。
下面提供示例代码:
1 NSException* ex = [[NSException alloc] initWithName:@"ExceptionName" // just for test 2 reason:@"XXX" 3 userInfo:nil]; 4 5 CustomNSException* ex = [[CustomNSException alloc] initWithName:@"CustomNSExceptionName" // just for test 6 reason:@"XXX" 7 userInfo:nil]; 8 9 @try { 10 bool error = YES; 11 if (error) { 12 @throw ex; 13 } 14 } 15 16 @catch ( CustomNSException *exception ) { 17 NSLog(@"CustomNSException.name = %@" , CustomNSException.name); 18 NSLog(@"CustomNSException.reason = %@" , CustomNSException.reason); 19 20 // 弹出警告框,提示异常信息 21 UIAlertView* alert = [[UIAlertView alloc] initWithTitle:CustomNSException.name 22 message:CustomNSException.reason 23 delegate:nil 24 cancelButtonTitle:nil 25 otherButtonTitles:nil]; 26 27 [alert show]; 28 [alert release]; 29 } 30 31 @catch ( NSException *exception ) { 32 NSLog(@"exception.name = %@" , exception.name); 33 NSLog(@"exception.reason = %@" , exception.reason); 34 } 35 36 @finally { 37 NSLog(@"@finally"); 38 }
参考: