这是我参与8月更文挑战的第24天,活动详情查看:8月更文挑战
@try@catch@finally捕获异常语法使用
try{
//1:抛出异常的代码
//2:代码
}catch(){
//3:代码
//4:抛出异常
}finally{
//5:代码
}
//6:代码
首先要明确的一点是:不管try是否抛出异常,finally语句块都会执行。
整个try,catch,finally执行有以下几种情况:
-
try语句块没有抛出异常。如果是这种情况,程序会执行try,finally以及finally块之后的代码; -
try语句块抛出了异常并且catch有匹配的异常。当遇到try里面抛出的异常后,try块里面剩下的代码就不执行了,跳转到catch块里面。- 第一种,抛出的异常被后面的
catch捕获,而catch又没有抛出新的异常,那么执行顺序是1->3->5->6; - 第二种,如果
catch里面又抛出新的异常,顺序是1->3->4->5,然后将新的异常返回给方法调用者,6就不执行了 ;
- 第一种,抛出的异常被后面的
-
try语句块抛出了异常,但是后面的catch没有能匹配的异常。那么会执行try和finally里面的语句也就是1->5,然后将该异常返回给方法调用者,不执行6
总结:
如果异常不能被捕捉的话,finally{}后面的语句就不会执行了,而finally{}一定被执行
抛异常
只有在极其罕见的情况下才会抛出异常,异常抛出之后,无需考虑恢复问题,而且应用程序此时也应该退出
//代码创建异常
@throw [NSException exceptionWithName:@"有问题" reason:@"这就是个问题" userInfo:nil];
控制台信息
*** Terminating app due to uncaught exception '有问题', reason: '这就是个问题'
*** First throw call stack:
(
0 CoreFoundation 0x00000001057541e6 __exceptionPreprocess + 294
1 libobjc.A.dylib 0x0000000104de9031 objc_exception_throw + 48
...
NSError
NSError对象中封装了三条错误信息
Error domain(错误范围,其类型为string)一般为:NSCocoaErrorDomainError code(错误码,类型为int)错误码可以定义为枚举Error info(用户信息,类型为dictionary)有关此错误的额外信息
- (void)doSomethingWithError:(NSError **)error{
NSDictionary *userInfo = [NSDictionary dictionaryWithObjectsAndKeys:@"由于文件不存在,无法打开", NSLocalizedDescriptionKey, @"失败原因:文件不存在", NSLocalizedFailureReasonErrorKey, @"恢复建议:请创建该文件",NSLocalizedRecoverySuggestionErrorKey,nil];
*error = [NSError errorWithDomain:NSCocoaErrorDomain code:404 userInfo:userInfo];
}
NSError *error;
[self doSomethingWithError:&error];
NSLog(@"%@",error);
log:
Error Domain=NSCocoaErrorDomain Code=404 "由于文件不存在,无法打开" UserInfo={NSLocalizedRecoverySuggestion=恢复建议:请创建该文件, NSLocalizedDescription=由于文件不存在,无法打开, NSLocalizedFailureReason=失败原因:文件不存在}