溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

asp.net中DBNull.Value,null,String.Empty區別有哪些

發布時間:2021-10-11 22:27:50 來源:億速云 閱讀:138 作者:iii 欄目:開發技術

本篇內容主要講解“asp.net中DBNull.Value,null,String.Empty區別有哪些”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“asp.net中DBNull.Value,null,String.Empty區別有哪些”吧!

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

到此,相信大家對“asp.net中DBNull.Value,null,String.Empty區別有哪些”有了更深的了解,不妨來實際操作一番吧!這里是億速云網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續學習!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

亚洲午夜精品一区二区_中文无码日韩欧免_久久香蕉精品视频_欧美主播一区二区三区美女