本文實(shí)例講述了asp.net中的check與uncheck關(guān)鍵字用法。分享給大家供大家參考。具體分析如下:
checked和unchecked是兩個(gè)不常用的關(guān)鍵字,但是確是非常有用的關(guān)鍵字,對(duì)此,建議測試時(shí)開啟全局checked編譯器選項(xiàng)。
1. 一段編譯沒經(jīng)由過程的代碼
復(fù)制代碼 代碼如下:
int a = int.MaxValue * 2;
以上代碼段編譯沒有經(jīng)由過程,在VS2010中會(huì)有一條紅色的波浪線指出這段代碼有題目:”The operation overflows at compile time in checked mode”。這說了然編譯器會(huì)在編譯時(shí)搜檢數(shù)學(xué)運(yùn)算是否溢出。然則編譯時(shí)能搜檢出溢出的景象僅限于應(yīng)用常量的運(yùn)算。2中的代碼編譯器就不報(bào)不失足誤來了。
2. 一段編譯經(jīng)由過程然則不克不及獲得正確成果的代碼
復(fù)制代碼 代碼如下:
int temp = int.MaxValue;
int a = temp * 2;
Console.Write(a);
我先把常量int.MaxValue的值給了姑且變量temp,然后應(yīng)用姑且變量乘以2策畫成果賦值給a;這段代碼是可以正常履行的,履行成果將輸出 -2。
這申明在運(yùn)行時(shí)默認(rèn)景象法度是不會(huì)搜檢算術(shù)運(yùn)算是否溢出的,cpu盡管算,對(duì)于它來講按規(guī)矩算就是了,成果對(duì)不合錯(cuò)誤不是他的錯(cuò)。
正常履行了,而成果是錯(cuò)誤的,這是很是危險(xiǎn)的景象,該如何避免這種危險(xiǎn)呢?請看3
3. 應(yīng)用checked關(guān)鍵字,溢出時(shí)報(bào)警
復(fù)制代碼 代碼如下:
int temp = int.MaxValue;
try
{
int a = checked(temp * 2);
Console.WriteLine(a);
}
catch (OverflowException)
{
Console.WriteLine("溢出了,要處理懲罰喲");
}
應(yīng)用checked關(guān)鍵字潤飾temp*2的策畫成果,并應(yīng)用try catch在產(chǎn)生溢出時(shí)做處理懲罰。以上代碼將輸出:“溢出了,要處理懲罰喲”
題目是若是一段代碼中有很多算術(shù)運(yùn)算都須要做溢出搜檢,那會(huì)有很多checked潤飾的表達(dá)式,怎么辦呢?請看4
4. checked關(guān)鍵字可以潤飾一個(gè)語句塊,請看下面代碼
復(fù)制代碼 代碼如下:
int temp = int.MaxValue;
try
{
checked
{
int num = temp / 20;
int a = temp * 2;
int c = temp * 1000;
}
}
catch (OverflowException)
{
Console.WriteLine("溢出了,要處理懲罰喲");
}
以上法度輸出成果和3一樣
5. checked在避免算術(shù)溢出方面很有效,那么unchecked呢,它有效嗎?答案是必然的,有時(shí)辰我們不須要正確的策畫成果,我們只是須要那么一個(gè)數(shù)罷了,至于溢出不溢出的關(guān)系不大,比如說生成一個(gè)對(duì)象的HashCode,比如說按照一個(gè)算法策畫出一個(gè)相對(duì)隨機(jī)數(shù),這都是不須要正確成果的。如下代碼片段
復(fù)制代碼 代碼如下:
class Person
{
public string Name { get; set; }
public string Title { get; set; }
public override int GetHashCode()
{
return unchecked(Name.GetHashCode() + Title.GetHashCode());
}
}
unchecked也可以潤飾語句塊,其用法和checked完全一樣。
6. checked和unchecked是可以嵌套應(yīng)用的,固然沒啥意義。語句是否是checked以比來嵌套的checked或者unchecked決意
7. 從IL中看checked關(guān)鍵字
C#代碼:
復(fù)制代碼 代碼如下:
static void Main(string[] args)
{
int a = int.MaxValue;
int b = a * 2;
int c = checked(a * 2);
int d = unchecked(a + 3);
Console.Read();
}
對(duì)應(yīng)IL
復(fù)制代碼 代碼如下:
.method private hidebysig static void Main(string[] args) cil managed
{
.entrypoint
// Code size 26 (0 x1a)
.maxstack 2
.locals init ([0] int32 a,
[1] int32 b,
[2] int32 c,
[3] int32 d)
IL_0000: nop
IL_0001: ldc.i4 0 x7fffffff
IL_0006: stloc.0
IL_0007: ldloc.0
IL_0008: ldc.i4.2
IL_0009: mul
IL_000a: stloc.1
IL_000b: ldloc.0
IL_000c: ldc.i4.2
IL_000d: mul.ovf
IL_000e: stloc.2
IL_000f: ldloc.0
IL_0010: ldc.i4.3
IL_0011: add
IL_0012: stloc.3
IL_0013: call int32 [mscorlib]System.Console::Read()
IL_0018: pop
IL_0019: ret
} // end of method Program::Main
請看IL中的紅色和綠色加重顯示代碼,可以看出應(yīng)用checked時(shí),IL的運(yùn)算是mul.ovf不應(yīng)用checked或者應(yīng)用unchecked時(shí)的IL運(yùn)算函數(shù)是mul或者add,不帶.ovf。
8. checked或者unchecked只影響其包抄的語句,不會(huì)影響到包抄的語句內(nèi)調(diào)用函數(shù)的代碼塊,如下示例:
復(fù)制代碼 代碼如下:
static void Main(string[] args)
{
int a = int.MaxValue;
int b = 20;
checked
{
int c = TestMethod(a, b);
Console.WriteLine(c);
}
}
static int TestMethod(int a, int b)
{
return a * b;
}
上方代碼將會(huì)正常履行,checked語句塊并未起到應(yīng)有的感化。
9. 全局開啟或者封閉checked編譯選項(xiàng)
在項(xiàng)目屬性頁上選擇“生成”選項(xiàng)卡,然后點(diǎn)擊“高等”按鈕,選中“搜檢數(shù)學(xué)運(yùn)算溢出”選項(xiàng),如下示意圖
希望本文所述對(duì)大家的asp.net程序設(shè)計(jì)有所幫助。
您可能感興趣的文章:- asp.net StringBuilder的用法 實(shí)例代碼
- ASP.NET(C#) String, StringBuilder 與 StringWriter性能比較
- .NET中的異常和異常處理用法分析
- .NET中的IO操作之文件流用法分析
- ASP.NET中repeater控件用法實(shí)例
- Asp.Net中索引器的用法分析
- ASP.NET中 script runat server 的用法
- 水晶報(bào)表asp.net的webform下基本用法實(shí)例
- ASP.NET中TimeSpan的用法實(shí)例解析
- .NET中StringBuilder用法實(shí)例分析