首先,“null”是C#中(VB.NET為Nothing),表示某個(gè)引用對(duì)象變量“未引用”任何實(shí)體時(shí)候的狀況(典型癥狀是如果調(diào)用這個(gè)變量的某個(gè)方法,會(huì)拋出NullException之類(lèi)的異常)。
String.Empty是一個(gè)靜態(tài)的公共變量,表示某String變量不包含任何字符(等同于"")。不過(guò)從性能上說(shuō),用String.Empty比聲明用一個(gè)""好一些——顯然地,前者是String類(lèi)的靜態(tài)變量,無(wú)論如何使用只產(chǎn)生一個(gè)實(shí)例,后者用幾次恐怕要產(chǎn)生幾次了。
代碼如下:
string str="";
//“”:表示在棧中分配了數(shù)據(jù)引用存儲(chǔ)區(qū)域,并在堆中創(chuàng)建了實(shí)際數(shù)據(jù)存儲(chǔ)區(qū)域,并將引用地址賦給了變量,在堆中分配了一個(gè)長(zhǎng)度為空的存儲(chǔ)空間。
string str=string.Empty;
//string.Empty: 表示在棧中分配了數(shù)據(jù)引用存儲(chǔ)區(qū)域,并在堆中創(chuàng)建了用于實(shí)際數(shù)據(jù)存儲(chǔ)的區(qū)域,并將引用地址賦給了變量,但在堆中創(chuàng)建的存儲(chǔ)空間未分配或未存儲(chǔ)數(shù)據(jù)。
至于DBNull.Value,也是一個(gè)靜態(tài)屬性。它唯獨(dú)用于數(shù)據(jù)庫(kù)(例如使用DataReader讀取數(shù)據(jù)的時(shí)候,又或者是DataTable中某行某列數(shù)據(jù)的比較時(shí)候)的“空數(shù)值”比較。因?yàn)樵赟QL中某個(gè)字段為Null只是說(shuō)明該字段“沒(méi)有任何值”,并不是C#中“不存在引用”。因此注意這些問(wèn)題:
1)如果用DataReader執(zhí)行ExecuteScalar,如果你不確定是否會(huì)獲取數(shù)據(jù),必須采用null進(jìn)行判斷(因?yàn)榭找茫?;如果你確信讀取至少一條數(shù)據(jù),但是不確定是否數(shù)據(jù)為空,可以使用DBNull.Value進(jìn)行數(shù)值判斷。
2)承接1,如果某條字段確信沒(méi)有任何數(shù)據(jù),等同于沒(méi)有任何字符,等同于String.Empty和"",因此完全可以用String.Empty或者""進(jìn)行判斷(重要結(jié)論:DbNull.Value=String.Empty="")。
3)另外,如果對(duì)string類(lèi)型的DataColumn進(jìn)行賦值(譬如賦值為null),既便如此,實(shí)際上在DataTable中不可能存一個(gè)null(為了和SQL實(shí)際數(shù)值對(duì)應(yīng)),會(huì)轉(zhuǎn)化成String.Empty或者是""。判斷方法同“重要結(jié)論”。
簡(jiǎn)單地說(shuō):
string str ="";
給你一張白紙;
string str = null;
連白紙也沒(méi)有。
string.Empty就相當(dāng)于""
一般用于字符串的初始化
比如:
代碼如下:
string a;
Console.WriteLine(a);//這里會(huì)報(bào)錯(cuò),因?yàn)闆](méi)有初始化a
而下面不會(huì)報(bào)錯(cuò):
代碼如下:
string a=string.Empty;
Console.WriteLine(a);
或者用于比較:
代碼如下:
if(a=="")
if(a==string.Empty)
上面兩句是一樣的效果。
string.Empty不分配存儲(chǔ)空間
""分配一個(gè)長(zhǎng)度為空的存儲(chǔ)空間
所以一般用string.Empty
為了以后跨平臺(tái),還是用string.empty
在 C# 中,大多數(shù)情況下 "" 和 string.Empty 可以互換使用。比如:
代碼如下:
string s = "";
string s2 = string.Empty;
if (s == string.Empty) {
//
}
if語(yǔ)句成立
判定為空字符串的幾種寫(xiě)法,按照性能從高到低的順序是:
s.Length == 0 優(yōu)于 s == string.Empty 優(yōu)于 s == ""
聲明:本網(wǎng)頁(yè)內(nèi)容旨在傳播知識(shí),若有侵權(quán)等問(wèn)題請(qǐng)及時(shí)與本網(wǎng)聯(lián)系,我們將在第一時(shí)間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com