概述C#语言异常处理

通用语言运行时(CLR)具有的一个很大的优势,C#语言异常处理是跨语言被标准化的。一个在C#中所引发的异常可以在VisualBasic客户中得到处理。不再有HRESULTs或者ISupportErrorInfo接口。
尽管跨C#语言异常处理的覆盖面很广,你稍为改变编译器的溢出处理行为,接着有趣的事情就开始了:你处理了该异常。要增加更多的手段,随后引发你所创建的异常。

校验(checked)和非校验(unchecked)语句

当你执行运算时,有可能会发生计算结果超出结果变量数据类型的有效范围。这种情况被称为溢出,依据不同的编程语言,你将被以某种方式通知——或者根本就没有被通知。
那么,C#如何处理溢出的呢?要找出其默认行为

 
 
 
  1. using System;  
  2.  
  3. class Factorial  
  4. {  
  5. public static void Main(string[] args)  
  6. {  
  7. long nFactorial = 1;  
  8. long nComputeTo = Int64.Parse(args[0]);  
  9.  
  10. long nCurDig = 1;  
  11. for (nCurDig=1;nCurDig <= nComputeTo; nCurDig++)  
  12. nFactorial *= nCurDig;  
  13.  
  14. Console.WriteLine("{0}! is {1}",nComputeTo, nFactorial);  
  15. }  

1.给溢出校验设置编译器

如果你想给整个应用程序控制溢出校验,C#编译器设置选择是正是你所要找的。默认地,溢出校验是禁用的。要明确
地要求它,运行以下编译器命令:
cscfactorial.cs/checked+

现在当你用2000参数执行应用程序时,CLR通知你溢出异常。

允许了溢出异常,阶乘代码产生了一个异常。按OK键离开对话框揭示了异常信息:
Exceptionoccurred:System.OverflowException
atFactorial.Main(System.String[])

现在你了解了溢出条件引发了一个System.OverflowException异常。

2.C#语言异常处理

如果你不想给整个应用程序允许溢出校验,仅给某些代码段允许校验,你可能会很舒适。对于这种场合,你可能象清单中显示的那样,使用校验语句。

 
 
 
  1. using System;  
  2.  
  3. class Factorial  
  4. {  
  5. public static void Main(string[] args)  
  6. {  
  7. long nFactorial = 1;  
  8. long nComputeTo = Int64.Parse(args[0]);  
  9.  
  10. long nCurDig = 1;  
  11.  
  12. for (nCurDig=1;nCurDig <= nComputeTo; nCurDig++)  
  13. checked { nFactorial *= nCurDig; }  
  14.  
  15. Console.WriteLine("{0}! is {1}",nComputeTo, nFactorial);  
  16. }  

甚至就如你运用标志checked-编译了该代码,在第13行中,溢出校验仍然会对乘法实现检查。错误信息保持一致。显示相反行为的语句是非校验(unchecked)。甚至如果允许了溢出校验(给编译器加上checked+标志),被unchecked语句所括住的代码也将不会引发溢出异常:

 
 
 
  1. unchecked
  2. {
  3. nFactorial *= nCurDig;
  4. }

【编辑推荐】

  1. 分析C#不安全代码
  2. 浅析C#调用ImageAnimator
  3. C#连接Access、SQL Server数据库
  4. 浅谈C#固定的和活动的变量
  5. 介绍C#中的值类型
THE END