iOS中接口与API设计(三)

195 阅读2分钟

这是我参与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没有能匹配的异常。那么会执行tryfinally里面的语句也就是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)一般为:NSCocoaErrorDomain
  • Error 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=失败原因:文件不存在}

关于iOS接口与API设计相关知识点