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