首先,“null”是C#中(VB.NET為Nothing),表示某個引用物件變數“未引用”任何實體時候的狀況(典型癥狀是如果調用這個變數的某個方法,會拋出NullException之類的異常)。
String.Empty是一個靜態公開變數,表示某String變數不包含任何字元(等同於"")。不過從效能上說,用String.Empty比聲明用一個""好一些——顯然地,前者是String類的靜態變數,無論如何使用只產生一個執行個體,後者用幾次恐怕要產生幾次了。
複製代碼 代碼如下:
string str="";
//“”:表示在棧中分配了資料引用儲存地區,並在堆中建立了實際資料存放區地區,並將引用地址賦給了變數,在堆中分配了一個長度為空白的儲存空間。
string str=string.Empty;
//string.Empty: 表示在棧中分配了資料引用儲存地區,並在堆中建立了用於實際資料存放區的地區,並將引用地址賦給了變數,但在堆中建立的儲存空間未分配或未儲存資料。
至於DBNull.Value,也是一個靜態屬性。它唯獨用於資料庫(例如使用DataReader讀取資料的時候,又或者是DataTable中某行某列資料的比較時候)的“空數值”比較。因為在SQL中某個欄位為Null只是說明該欄位“沒有任何值”,並不是C#中“不存在引用”。因此注意這些問題:
1)如果用DataReader執行ExecuteScalar,如果你不確定是否會擷取資料,必須採用null進行判斷(因為空白引用);如果你確信讀取至少一條資料,但是不確定是否資料為空白,可以使用DBNull.Value進行數值判斷。
2)承接1,如果某條欄位確信沒有任何資料,等同於沒有任何字元,等同於String.Empty和"",因此完全可以用String.Empty或者""進行判斷(重要結論:DbNull.Value=String.Empty="")。
3)另外,如果對string類型的DataColumn進行賦值(譬如賦值為null),既便如此,實際上在DataTable中不可能存一個null(為了和SQL實際數值對應),會轉化成String.Empty或者是""。判斷方法同“重要結論”。
簡單地說:
string str ="";
給你一張白紙;
string str = null;
連白紙也沒有。
string.Empty就相當於""
一般用於字串的初始化
比如:
複製代碼 代碼如下:
string a;
Console.WriteLine(a);//這裡會報錯,因為沒有初始化a
而下面不會報錯:
複製代碼 代碼如下:
string a=string.Empty;
Console.WriteLine(a);
或者用於比較:
複製代碼 代碼如下:
if(a=="")
if(a==string.Empty)
上面兩句是一樣的效果。
string.Empty不分配儲存空間
""分配一個長度為空白的儲存空間
所以一般用string.Empty
為了以後跨平台,還是用string.empty
在 C# 中,大多數情況下 "" 和 string.Empty 可以互換使用。比如:
複製代碼 代碼如下:
string s = "";
string s2 = string.Empty;
if (s == string.Empty) {
//
}
if語句成立
判定為空白字串的幾種寫法,按照效能從高到低的順序是:
s.Length == 0 優於 s == string.Empty 優於 s == ""