处理异常
@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 帮助手册。