| 在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程序员都必须了解的。 |