asp.net中的check與uncheck關(guān)鍵字用法解析
本文實(shí)例講述了asp.net中的check與uncheck關(guān)鍵字用法。分享給大家供大家參考。具體分析如下:
checked和unchecked是兩個(gè)不常用的關(guān)鍵字,但是確是非常有用的關(guān)鍵字,對(duì)此,建議測(cè)試時(shí)開(kāi)啟全局checked編譯器選項(xiàng)。
1. 一段編譯沒(méi)經(jīng)由過(guò)程的代碼
以上代碼段編譯沒(méi)有經(jīng)由過(guò)程,在VS2010中會(huì)有一條紅色的波浪線指出這段代碼有題目:”The operation overflows at compile time in checked mode”。這說(shuō)了然編譯器會(huì)在編譯時(shí)搜檢數(shù)學(xué)運(yùn)算是否溢出。然則編譯時(shí)能搜檢出溢出的景象僅限于應(yīng)用常量的運(yùn)算。2中的代碼編譯器就不報(bào)不失足誤來(lái)了。
2. 一段編譯經(jīng)由過(guò)程然則不克不及獲得正確成果的代碼
int a = temp * 2;
Console.Write(a);
我先把常量int.MaxValue的值給了姑且變量temp,然后應(yīng)用姑且變量乘以2策畫(huà)成果賦值給a;這段代碼是可以正常履行的,履行成果將輸出 -2。
這申明在運(yùn)行時(shí)默認(rèn)景象法度是不會(huì)搜檢算術(shù)運(yùn)算是否溢出的,cpu盡管算,對(duì)于它來(lái)講按規(guī)矩算就是了,成果對(duì)不合錯(cuò)誤不是他的錯(cuò)。
正常履行了,而成果是錯(cuò)誤的,這是很是危險(xiǎn)的景象,該如何避免這種危險(xiǎn)呢?請(qǐng)看3
3. 應(yīng)用checked關(guān)鍵字,溢出時(shí)報(bào)警
try
{
int a = checked(temp * 2);
Console.WriteLine(a);
}
catch (OverflowException)
{
Console.WriteLine("溢出了,要處理懲罰喲");
}
應(yīng)用checked關(guān)鍵字潤(rùn)飾temp*2的策畫(huà)成果,并應(yīng)用try catch在產(chǎn)生溢出時(shí)做處理懲罰。以上代碼將輸出:“溢出了,要處理懲罰喲”
題目是若是一段代碼中有很多算術(shù)運(yùn)算都須要做溢出搜檢,那會(huì)有很多checked潤(rùn)飾的表達(dá)式,怎么辦呢?請(qǐng)看4
4. checked關(guān)鍵字可以潤(rùn)飾一個(gè)語(yǔ)句塊,請(qǐng)看下面代碼
try
{
checked
{
int num = temp / 20;
int a = temp * 2;
int c = temp * 1000;
}
}
catch (OverflowException)
{
Console.WriteLine("溢出了,要處理懲罰喲");
}
以上法度輸出成果和3一樣
5. checked在避免算術(shù)溢出方面很有效,那么unchecked呢,它有效嗎?答案是必然的,有時(shí)辰我們不須要正確的策畫(huà)成果,我們只是須要那么一個(gè)數(shù)罷了,至于溢出不溢出的關(guān)系不大,比如說(shuō)生成一個(gè)對(duì)象的HashCode,比如說(shuō)按照一個(gè)算法策畫(huà)出一個(gè)相對(duì)隨機(jī)數(shù),這都是不須要正確成果的。如下代碼片段
{
public string Name { get; set; }
public string Title { get; set; }
public override int GetHashCode()
{
return unchecked(Name.GetHashCode() + Title.GetHashCode());
}
}
unchecked也可以潤(rùn)飾語(yǔ)句塊,其用法和checked完全一樣。
6. checked和unchecked是可以嵌套應(yīng)用的,固然沒(méi)啥意義。語(yǔ)句是否是checked以比來(lái)嵌套的checked或者unchecked決意
7. 從IL中看checked關(guān)鍵字
C#代碼:
{
int a = int.MaxValue;
int b = a * 2;
int c = checked(a * 2);
int d = unchecked(a + 3);
Console.Read();
}
對(duì)應(yīng)IL
{
.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
請(qǐng)看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只影響其包抄的語(yǔ)句,不會(huì)影響到包抄的語(yǔ)句內(nèi)調(diào)用函數(shù)的代碼塊,如下示例:
{
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ǔ)句塊并未起到應(yīng)有的感化。
9. 全局開(kāi)啟或者封閉checked編譯選項(xiàng)
在項(xiàng)目屬性頁(yè)上選擇“生成”選項(xiàng)卡,然后點(diǎn)擊“高等”按鈕,選中“搜檢數(shù)學(xué)運(yùn)算溢出”選項(xiàng),如下示意圖
希望本文所述對(duì)大家的asp.net程序設(shè)計(jì)有所幫助。
相關(guān)文章
.NET實(shí)現(xiàn)倉(cāng)儲(chǔ)Repository(AI)的操作方法
倉(cāng)儲(chǔ)模式是一種在應(yīng)用程序中使用的設(shè)計(jì)模式,它將數(shù)據(jù)訪問(wèn)邏輯與業(yè)務(wù)邏輯分離,通過(guò)倉(cāng)儲(chǔ)接口和倉(cāng)儲(chǔ)實(shí)現(xiàn)類,您可以定義和實(shí)現(xiàn)數(shù)據(jù)的增刪改查操作,這篇文章主要介紹了.NET?實(shí)現(xiàn)倉(cāng)儲(chǔ)Repository(AI),需要的朋友可以參考下2023-09-09asp.net Repeater綁定時(shí)使用函數(shù)
asp.net repeater綁定函數(shù)使用實(shí)例2008-08-08asp.net 利用NPOI導(dǎo)出Excel通用類的方法
本篇文章主要介紹了asp.net 利用NPOI導(dǎo)出Excel通用類的方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-06-06某個(gè)aspx頁(yè)面突然死了連日志也沒(méi)有的解決方法
某個(gè)aspx頁(yè)面突然死了連日志也沒(méi)有,朋友提醒event viewer里看看,果然錯(cuò)誤在那里,有此情況的朋友可以參考下2013-08-08Asp.Net Core使用swagger生成api文檔的完整步驟
這篇文章主要給大家介紹了關(guān)于Asp.Net Core使用swagger生成api文檔的完整步驟,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用Asp.Net Core具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-12-12