C#中的异常捕获机制(try catch finally)

  1. C#中的异常捕获机制(try catch finally) //转自:http://blog.csdn.net/zevin/article/details/6901489

  2. 一、C#的异常处理所用到关键字  
  3. try 用于检查发生的异常,并帮助发送任何可能的异常。  
  4. catch 以控制权更大的方式处理错误,可以有多个catch子句。  
  5. finally 无论是否引发了异常,finally的代码块都将被执行。  
  6. throw 用于引发异常,可引发预定义异常和自定义异常。  
  7.   
  8. 二、C#异常处理的格式  
  9. try  
  10. {  
  11. 程序代码块;  
  12. }  
  13. catch(Exception e)  
  14. {  
  15. 异常处理代码块;  
  16. }  
  17. finally  
  18. {  
  19. 无论是否发生异常,均要执行的代码块;  
  20. }  
  21.   
  22. 三、异常处理实战  
  23. 一个除数和零的简单例子:  
  24. public class DivisorIsZero  
  25. {  
  26. private static void Main()  
  27. {  
  28. int dividend=10;  
  29. int divisor1=0;  
  30. int divisor2=5;  
  31. int DivideValue;  
  32.   
  33. try  
  34. {  
  35. DivideValue=dividend/divisor1; //(1)  
  36. //DivideValue=dividend/divisor2; //(2)  
  37. System.Console.WriteLine("DivideValue={0}",DivideValue);//(3)这一行将不会被执行。  
  38. }  
  39. catch  
  40. {  
  41. System.Console.WriteLine("传递过来的异常值为:{0}",e);  
  42. }  
  43. finally  
  44. {  
  45. System.Console.WriteLine("无论是否发生异常,我都会显示。");  
  46. }  
  47. }  
  48. }  
  49. 注:(1)行被执行则会抛出一个异常,如果没有catch语句,程序会异常终止,使用不带参数的catch子句,则可以捕获任意类型的异常。  
  50. 如果将(1)行注释掉,启用(2)行,这意味该程序运行时不会出现异常,从输出可知,finally代码块仍将被执行。  
  51.   
  52. 可以给try语句提供多个catch语句,以捕获特定的异常,如上例中:0作为除数则会引发DivideByZeroException类型的异常,上例中的catch语句可以作如下修改:  
  53. catch(DivideByZeroException e)  
  54. {  
  55. System.Console.WriteLine("零不能作为除数!异常值为:\n{0}",e);  
  56. }  
  57. catch(Exception e)  
  58. {  
  59. System.Console.WriteLine("并非\''零作为除数引发的异常\"!异常值为:\n{0}",e);  
  60. }  
  61.   
  62. 为什么还要加上一个catch(Exception e)子句呢?原因很简单,catch(DivideByZeroException e)子句只能捕获特定的异常,try内的程序代码可能还会产生其它的异常,这些异常只能由catch(Exception e)来捕获了。  
  63.   
  64. 下表给出了一些常见的异常:  
  65.   
  66. System名称空间中常用的异常类  
  67.   
  68. 异常类名称 简单描述  
  69.   
  70. MemberAccessException 访问错误:类型成员不能被访问  
  71.   
  72. ArgumentException 参数错误:方法的参数无效  
  73.   
  74. ArgumentNullException 参数为空:给方法传递一个不可接受的空参数  
  75.   
  76. ArithmeticException 数学计算错误:由于数学运算导致的异常,覆盖面广。  
  77.   
  78. ArrayTypeMismatchException 数组类型不匹配  
  79.   
  80. DivideByZeroException 被零除  
  81.   
  82. FormatException 参数的格式不正确  
  83.   
  84. IndexOutOfRangeException 索引超出范围,小于0或比最后一个元素的索引还大  
  85.   
  86. InvalidCastException 非法强制转换,在显式转换失败时引发  
  87.   
  88. MulticastNotSupportedException 不支持的组播:组合两个非空委派失败时引发  
  89.   
  90. NotSupportedException 调用的方法在类中没有实现  
  91.   
  92. NullReferenceException 引用空引用对象时引发  
  93.   
  94. OutOfMemoryException 无法为新语句分配内存时引发,内存不足  
  95.   
  96. OverflowException 溢出  
  97.   
  98. StackOverflowException 栈溢出  
  99.   
  100. TypeInitializationException 错误的初始化类型:静态构造函数有问题时引发  
  101.   
  102. NotFiniteNumberException 无限大的值:数字不合法  
  103.   
  104. 四、定义自己的异常类  
  105.   
  106. 除了预定义的异常外,我们还可以创建自己的异常,过程比较简单:  
  107.   
  108. 一声明一个异常,格式如下:  
  109.   
  110. class ExceptionName:Exception{}  
  111.   
  112. 二引发自己的异常:  
  113.   
  114. throw(ExceptionName);  
  115.   
  116. 看一个例子:  
  117. class IAmSecondGrade:System.Exception{}//声明异常  
  118.   
  119. class SecondGrade  
  120. {  
  121. public static int mul(int first,int second)  
  122. {  
  123. if(first>100||second>100)  
  124. throw new IAmSecondGrade();//引发异常  
  125. return (first*second);  
  126. }  
  127.   
  128. public static void Main()  
  129. {  
  130. int mul_value;  
  131.   
  132. try  
  133. {  
  134. mul_value=mul(99,56);  
  135. System.Console.WriteLine("99与56积为:{0}",mul_value);  
  136. mul_value=mul(101,4);  
  137. System.Console.WriteLine("出现异常,这行是不会被执行的。");  
  138. }  
  139. catch(IAmSecondGrade)//捕获自定义的异常  
  140. {  
  141. System.Console.WriteLine("我才上二年级,超过100的乘法我不会。嘿嘿,我自定义的异常。");  
  142. }  
  143. catch(System.Exception e)  
  144. {  
  145. System.Console.WriteLine("非自定义异常。其值为:{0}",e);  
  146. }  
  147. }  
  148. }  

posted on 2015-05-29 14:36  call_from_dream  阅读(395)  评论(0编辑  收藏  举报

导航