首先,“null”是C#中(VB.NET為Nothing),表示某個引用對象變量“未引用”任何實體時候的狀況(典型癥狀是如果調用這個變量的某個方法,會拋出NullException之類的異常)。
String.Empty是一個靜態的公共變量,表示某String變量不包含任何字符(等同于"")。不過從性能上說,用String.Empty比聲明用一個""好一些——顯然地,前者是String類的靜態變量,無論如何使用只產生一個實例,后者用幾次恐怕要產生幾次了。
string str="";
//“”:表示在棧中分配了數據引用存儲區域,并在堆中創建了實際數據存儲區域,并將引用地址賦給了變量,在堆中分配了一個長度為空的存儲空間。
string str=string.Empty;
//string.Empty: 表示在棧中分配了數據引用存儲區域,并在堆中創建了用于實際數據存儲的區域,并將引用地址賦給了變量,但在堆中創建的存儲空間未分配或未存儲數據。
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 a;
Console.WriteLine(a);//這里會報錯,因為沒有初始化a
string s = "";
string s2 = string.Empty;
if (s == string.Empty) {
//
}