您的位置:首页 > 其它

.net异常处理

2015-09-21 16:50 344 查看
http://www.cnblogs.com/eagle1986/archive/2012/01/18/2325490.html

在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程序员都必须了解的。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: