概述C#語(yǔ)言異常處理
通用語(yǔ)言運(yùn)行時(shí)(CLR)具有的一個(gè)很大的優(yōu)勢(shì),C#語(yǔ)言異常處理是跨語(yǔ)言被標(biāo)準(zhǔn)化的。一個(gè)在C#中所引發(fā)的異??梢栽赩isualBasic客戶(hù)中得到處理。不再有HRESULTs或者ISupportErrorInfo接口。
盡管跨C#語(yǔ)言異常處理的覆蓋面很廣,你稍為改變編譯器的溢出處理行為,接著有趣的事情就開(kāi)始了:你處理了該異常。要增加更多的手段,隨后引發(fā)你所創(chuàng)建的異常。
校驗(yàn)(checked)和非校驗(yàn)(unchecked)語(yǔ)句
當(dāng)你執(zhí)行運(yùn)算時(shí),有可能會(huì)發(fā)生計(jì)算結(jié)果超出結(jié)果變量數(shù)據(jù)類(lèi)型的有效范圍。這種情況被稱(chēng)為溢出,依據(jù)不同的編程語(yǔ)言,你將被以某種方式通知——或者根本就沒(méi)有被通知。
那么,C#如何處理溢出的呢?要找出其默認(rèn)行為
- using System;
- class Factorial
- {
- public static void Main(string[] args)
- {
- long nFactorial = 1;
- long nComputeTo = Int64.Parse(args[0]);
- long nCurDig = 1;
- for (nCurDig=1;nCurDig <= nComputeTo; nCurDig++)
- nFactorial *= nCurDig;
- Console.WriteLine("{0}! is {1}",nComputeTo, nFactorial);
- }
- }
1.給溢出校驗(yàn)設(shè)置編譯器
如果你想給整個(gè)應(yīng)用程序控制溢出校驗(yàn),C#編譯器設(shè)置選擇是正是你所要找的。默認(rèn)地,溢出校驗(yàn)是禁用的。要明確
地要求它,運(yùn)行以下編譯器命令:
cscfactorial.cs/checked+
現(xiàn)在當(dāng)你用2000參數(shù)執(zhí)行應(yīng)用程序時(shí),CLR通知你溢出異常。
允許了溢出異常,階乘代碼產(chǎn)生了一個(gè)異常。按OK鍵離開(kāi)對(duì)話框揭示了異常信息:
Exceptionoccurred:System.OverflowException
atFactorial.Main(System.String[])
現(xiàn)在你了解了溢出條件引發(fā)了一個(gè)System.OverflowException異常。
2.C#語(yǔ)言異常處理
如果你不想給整個(gè)應(yīng)用程序允許溢出校驗(yàn),僅給某些代碼段允許校驗(yàn),你可能會(huì)很舒適。對(duì)于這種場(chǎng)合,你可能象清單中顯示的那樣,使用校驗(yàn)語(yǔ)句。
- using System;
- class Factorial
- {
- public static void Main(string[] args)
- {
- long nFactorial = 1;
- long nComputeTo = Int64.Parse(args[0]);
- long nCurDig = 1;
- for (nCurDig=1;nCurDig <= nComputeTo; nCurDig++)
- checked { nFactorial *= nCurDig; }
- Console.WriteLine("{0}! is {1}",nComputeTo, nFactorial);
- }
- }
甚至就如你運(yùn)用標(biāo)志checked-編譯了該代碼,在第13行中,溢出校驗(yàn)仍然會(huì)對(duì)乘法實(shí)現(xiàn)檢查。錯(cuò)誤信息保持一致。顯示相反行為的語(yǔ)句是非校驗(yàn)(unchecked)。甚至如果允許了溢出校驗(yàn)(給編譯器加上checked+標(biāo)志),被unchecked語(yǔ)句所括住的代碼也將不會(huì)引發(fā)溢出異常:
- unchecked
- {
- nFactorial *= nCurDig;
- }
【編輯推薦】