asp.net中DBNull.Value,null,String.Empty區別淺析_實用技巧

來源:互聯網
上載者:User

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

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.