在C#中,当出现某种异常时,就会创建一个异常对象。这个对象包含有助于跟踪问题的信息。 我们可以创建自己的异常类,但.NET已经提供了许多预定义的异常类
异常类Exception
SystemException 这个是由公共语言运行库引发的异常,派生于systemExecption类 ApplicationException 由用户程序执行的异常,派生于ApplicationException类
try-catch语句由一个try块后跟一个或多个catch子句构成
在catch块中可以使用throw语句再次引发已由catch语句捕获异常
throw语句用于发出在程序执行期间出现反常情况(异常)的信息。引发的异常是一个对象,该对象的类是从System.Exception派生的。
通常throw语句与try-catch或try-finally语句一起使用。当引发异常时,程序查找处理此异常的catch语句。也可以用throw语句重新引发已捕获的异常。 try { //............ } //捕获异常 catch(Exception ex) { //再次引发异常 throw new Exception(ex.ToString()); }
System.Exception的常用属性
GetType() 获取异常的类型 HelpLink 连接到一个帮助文件上,以提供该异常的更多信息 Message 描述错误情况的文本(告诉用户发生了什么事) Source 导致异常的应用程序或对象名 StackTrace 堆栈上方法调用的信息,它有助于跟踪引发异常的方法,确定错误发生的位置,如果有可用的调试信息(即有<程序名>.pdb文件存在),还可以显示源文件名和程序行号。 TargetSite 引发异常的方法的.NET反射对象 InnerException 如果异常是在catch块中引发的,它就会包含把代码发送到catch块中的异常对象
比如: 在一个类中定义自己的异常类: public class ExceptionClass : Exception {
public ExceptionClass(string mess):base(mess) { } }
在另一个类中定义: public class Test { public string TestMod(int testmun) { if (testmun==0) { //抛出异常信息 throw new ExceptionClass("发生了为0的异常"); } else { return "正常返回"; } } }
主程序调用:
static void Main(string[] args) { Test a = new Test(); try { string re = a.TestMod(0); System.Windows.Forms.MessageBox.Show(re); } catch (ExceptionClass ecc) {
System.Windows.Forms.MessageBox.Show(ecc.Message);
}
}
关于CLR的 “两轮遍历”异常处理策略。
当应用 程序拥有多层嵌套的异常捕获结构时,如果最底层(其实在中间层也一样)发生了异常,CLR将优先在引发异常的那一层去搜索catch语句块,看看有没有“兼容”
此类型异常的处理代码 ,如果没有,就“跳到”上一层去搜索,如果上一层还没有,继续搜索上一层的“上一层”,由此直到应用 程序的最顶层。
这就是CLR处理嵌套异常捕获结构应用程序的“第一轮”遍历-----查找合适的异常处理程序。
如果在某一层找到了异常处理程序,注意,CLR并不会马上执行之,而是回到"事故现场",再次进行“第二轮”遍历,执行所有“中间”层次的finally 语句块,然后,执行
找到异常处理程序 ,最后,再从本层开始一直遍历到最顶层,执行所有的finally语句块。
这个“两轮遍历”的异常处理策略是所有.NET程序员都必须了解的。 |