处理异常

@try

{

//可能出错的代码

}

@catch(异常 1 ex)

{

//错误后的执行方案1

}

@catch(异常 2 ex)

{

//错误后的执行方案2

}

.....

@finally

{

//回收资源

}

注意:

@try 与if语句不一样,@try块后的花括号即使只有一行代码也不可省略。@catch块后的花括号也不能省略

@try块内生成的变量是代码块内的局部变量,只在@try块中生效。

NSException类是OC所有异常类的根类,其他异常类都应该通过该类进行派生

进行异常捕获时不仅应该把NSException对应的@catch块放在最后,所有父类异常的@chatch块都应该排在子类异常@catch块的后面(简称为先处理小异常,在处理大异常),否则将出现后面的@catch块将得不到执行的机会。很不幸的是,OC编译器不会对这条规则做出任何检查,需程序员自己保证。

可以通过异常形参来访问异常信息。

所偶异常对象都包含如下几个常用方法:

name:返回该异常详细的名称

reason:返回引发该异常的原因

userInfo:返回引发该异常的用户附加信息,该方法的返回值是一个NSDictionary对象。

以上方法相当于getter方法,都可以使用点语法。

@finally回收资源,特别是没有使用ARC时。回收的是@try块中调用的物理资源。

不可再@finally块中加入return或@throw,这将导致@try和@catch块中的return@throw语句失效。原因:当在@try和@catch块中遇到retur n或@throw时,程序先执行@finally块,执行结束后,才会执行return@throw。

6.5.4 抛出异常与自定义异常类

@throw语句可以单独使用,其抛出的不是异常类,而是一个异常实例,每次仅可抛出一个。

格式:

@throw ExceptionInstance;

大部分时候,我们直接抛出NSException对象既可。在少数情况下,OC也可抛出自定义异常,此时可通过一场的类名来包含一些异常的信息。

用户自定义异常都应该继承NSException基类,可自行增加额外属性。

isKindOfClass:  isMemberOfClass方法 判断该类所属的类

respondsToSelector:判断该实例是否可调用指定方法

conformsToProtocol: 判断该对象是否遵守指定协议

methodForSelector: 返回指定方法实现的指针

直接调用运行时函数进行动态编程。运行时系统是一个动态共享库,由系列位于/usr/include/objc目录的头文件中的函数和数据结构组成,这些工具都是c风格的,他们并不是OC编程必需的。如果需要理解这些运行时函数的功能和用法,可参考Xcode帮助系统的Objective-C runtime Reference 帮助手册。

你可能感兴趣的:(处理异常)