程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> .NET網頁編程 >> ASP.NET >> ASP.NET基礎 >> asp.net中DBNull.Value,null,String.Empty區別淺析

asp.net中DBNull.Value,null,String.Empty區別淺析

編輯:ASP.NET基礎

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

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved