首先,“null”是C#中(VB.NET為Nothing),表示某個(gè)引用對象變量“未引用”任何實(shí)體時(shí)候的狀況(典型癥狀是如果調(diào)用這個(gè)變量的某個(gè)方法,會拋出NullException之類的異常)。
String.Empty是一個(gè)靜態(tài)的公共變量,表示某String變量不包含任何字符(等同于"")。不過從性能上說,用String.Empty比聲明用一個(gè)""好一些——顯然地,前者是String類的靜態(tài)變量,無論如何使用只產(chǎn)生一個(gè)實(shí)例,后者用幾次恐怕要產(chǎn)生幾次了。
string str="";
//“”:表示在棧中分配了數(shù)據(jù)引用存儲區(qū)域,并在堆中創(chuàng)建了實(shí)際數(shù)據(jù)存儲區(qū)域,并將引用地址賦給了變量,在堆中分配了一個(gè)長度為空的存儲空間。
string str=string.Empty;
//string.Empty: 表示在棧中分配了數(shù)據(jù)引用存儲區(qū)域,并在堆中創(chuàng)建了用于實(shí)際數(shù)據(jù)存儲的區(qū)域,并將引用地址賦給了變量,但在堆中創(chuàng)建的存儲空間未分配或未存儲數(shù)據(jù)。
1)如果用DataReader執(zhí)行ExecuteScalar,如果你不確定是否會獲取數(shù)據(jù),必須采用null進(jìn)行判斷(因?yàn)榭找茫?;如果你確信讀取至少一條數(shù)據(jù),但是不確定是否數(shù)據(jù)為空,可以使用DBNull.Value進(jìn)行數(shù)值判斷。
2)承接1,如果某條字段確信沒有任何數(shù)據(jù),等同于沒有任何字符,等同于String.Empty和"",因此完全可以用String.Empty或者""進(jìn)行判斷(重要結(jié)論:DbNull.Value=String.Empty="")。
3)另外,如果對string類型的DataColumn進(jìn)行賦值(譬如賦值為null),既便如此,實(shí)際上在DataTable中不可能存一個(gè)null(為了和SQL實(shí)際數(shù)值對應(yīng)),會轉(zhuǎn)化成String.Empty或者是""。判斷方法同“重要結(jié)論”。
string a;
Console.WriteLine(a);//這里會報(bào)錯(cuò),因?yàn)闆]有初始化a
string s = "";
string s2 = string.Empty;
if (s == string.Empty) {
//
}