首先,“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 == ""