asp.net中DBNull.Value,null,String.Empty區(qū)別淺析
首先,“null”是C#中(VB.NET為Nothing),表示某個(gè)引用對象變量“未引用”任何實(shí)體時(shí)候的狀況(典型癥狀是如果調(diào)用這個(gè)變量的某個(gè)方法,會(huì)拋出NullException之類的異常)。
String.Empty是一個(gè)靜態(tài)的公共變量,表示某String變量不包含任何字符(等同于"")。不過從性能上說,用String.Empty比聲明用一個(gè)""好一些——顯然地,前者是String類的靜態(tài)變量,無論如何使用只產(chǎn)生一個(gè)實(shí)例,后者用幾次恐怕要產(chǎn)生幾次了。
string str="";
//“”:表示在棧中分配了數(shù)據(jù)引用存儲(chǔ)區(qū)域,并在堆中創(chuàng)建了實(shí)際數(shù)據(jù)存儲(chǔ)區(qū)域,并將引用地址賦給了變量,在堆中分配了一個(gè)長度為空的存儲(chǔ)空間。
string str=string.Empty;
//string.Empty: 表示在棧中分配了數(shù)據(jù)引用存儲(chǔ)區(qū)域,并在堆中創(chuàng)建了用于實(shí)際數(shù)據(jù)存儲(chǔ)的區(qū)域,并將引用地址賦給了變量,但在堆中創(chuàng)建的存儲(chǔ)空間未分配或未存儲(chǔ)數(shù)據(jù)。
至于DBNull.Value,也是一個(gè)靜態(tài)屬性。它唯獨(dú)用于數(shù)據(jù)庫(例如使用DataReader讀取數(shù)據(jù)的時(shí)候,又或者是DataTable中某行某列數(shù)據(jù)的比較時(shí)候)的“空數(shù)值”比較。因?yàn)樵赟QL中某個(gè)字段為Null只是說明該字段“沒有任何值”,并不是C#中“不存在引用”。因此注意這些問題:
1)如果用DataReader執(zhí)行ExecuteScalar,如果你不確定是否會(huì)獲取數(shù)據(jù),必須采用null進(jìn)行判斷(因?yàn)榭找茫蝗绻愦_信讀取至少一條數(shù)據(jù),但是不確定是否數(shù)據(jù)為空,可以使用DBNull.Value進(jìn)行數(shù)值判斷。
2)承接1,如果某條字段確信沒有任何數(shù)據(jù),等同于沒有任何字符,等同于String.Empty和"",因此完全可以用String.Empty或者""進(jìn)行判斷(重要結(jié)論:DbNull.Value=String.Empty="")。
3)另外,如果對string類型的DataColumn進(jìn)行賦值(譬如賦值為null),既便如此,實(shí)際上在DataTable中不可能存一個(gè)null(為了和SQL實(shí)際數(shù)值對應(yīng)),會(huì)轉(zhuǎn)化成String.Empty或者是""。判斷方法同“重要結(jié)論”。
簡單地說:
string str ="";
給你一張白紙;
string str = null;
連白紙也沒有。
string.Empty就相當(dāng)于""
一般用于字符串的初始化
比如:
string a;
Console.WriteLine(a);//這里會(huì)報(bào)錯(cuò),因?yàn)闆]有初始化a
而下面不會(huì)報(bào)錯(cuò):
string a=string.Empty;
Console.WriteLine(a);
或者用于比較:
if(a=="")
if(a==string.Empty)
上面兩句是一樣的效果。
string.Empty不分配存儲(chǔ)空間
""分配一個(gè)長度為空的存儲(chǔ)空間
所以一般用string.Empty
為了以后跨平臺(tái),還是用string.empty
在 C# 中,大多數(shù)情況下 "" 和 string.Empty 可以互換使用。比如:
string s = "";
string s2 = string.Empty;
if (s == string.Empty) {
//
}
if語句成立
判定為空字符串的幾種寫法,按照性能從高到低的順序是:
s.Length == 0 優(yōu)于 s == string.Empty 優(yōu)于 s == ""
- asp.net String.IsNullOrEmpty 方法
- asp.net String.Empty NULL 不同之處
- asp.net 用戶在線退出更新實(shí)現(xiàn)代碼
- ASP.NET MVC運(yùn)行出現(xiàn)Uncaught TypeError: Cannot set property __MVC_FormValidation of null的解決方法
- asp.net中Null在從數(shù)據(jù)庫讀取的時(shí)候的一點(diǎn)點(diǎn)小技巧
- sql server中批量插入與更新兩種解決方案分享(asp.net)
- asp.net中g(shù)ridview的查詢、分頁、編輯更新、刪除的實(shí)例代碼
- 解決asp.net mvc UpdateModel更新對象后出現(xiàn)null問題的方法
相關(guān)文章
ASP.NET Core使用SkiaSharp實(shí)現(xiàn)驗(yàn)證碼的示例代碼
本篇文章主要介紹了ASP.NET Core使用SkiaSharp實(shí)現(xiàn)驗(yàn)證碼的示例代碼,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-12-12ASP.NET與ASP互通COOKIES的一點(diǎn)經(jīng)驗(yàn)
ASP與ASP.NET互相整合時(shí),其中文COOKIES信息無法被互通共享,當(dāng)使用ASP.NET寫入中文COOKIES信息后,使用ASP進(jìn)行讀取,讀出來的卻是亂碼,而非中文。2010-03-03ASP.NET中DropDownList和ListBox實(shí)現(xiàn)兩級聯(lián)動(dòng)功能
這篇文章主要介紹了ASP.NET中DropDownList和ListBox實(shí)現(xiàn)兩級聯(lián)動(dòng)功能的相關(guān)資料,需要的朋友可以參考下2016-01-01asp.net(c#)ref,out ,params的區(qū)別
C#中有三個(gè)關(guān)鍵字-ref,out ,params,雖然本人不喜歡這三個(gè)關(guān)鍵字,因?yàn)樗鼈円伤破茐拿嫦驅(qū)ο筇匦?。但是既然m$把融入在c#體系中,那么我們就來認(rèn)識(shí)一下參數(shù)修飾符ref,out ,params吧,還有它們的區(qū)別。2009-12-12ASP.net 頁面被關(guān)閉后,服務(wù)器端是否仍然執(zhí)行中?
當(dāng)一個(gè)正在執(zhí)行中的ASPX頁面執(zhí)行到一半的時(shí)候,瀏覽器中你關(guān)閉了這個(gè)頁面,服務(wù)器端對應(yīng)的這個(gè)頁面的代碼仍然在執(zhí)行么?2008-08-08