吴佳鑫的个人专栏

当日事当日毕,没有任何借口

导航

.net异常处理

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

posted on 2012-01-18 14:02  _eagle  阅读(3693)  评论(0编辑  收藏  举报