在C#2.0中使用Nullable可空型別
在C#1.x的版本中,一個值型別變數是不可以被賦予null值的,否則會產生異常。在C#2.0中,微軟提供了Nullable型別,允許用它定義包含null值(即空值)的資料型別,這對處理資料庫中包含可選欄位以及很多方面都有很大幫助。 定義Nullable型別
定義一個nullable型別非常類似於定義一個非nullable型別。不同之處在於使用型別修飾符“?”。比如定義一個整型如下:
int myInt = 1;要使一個整型變數可以儲存一個null值,可以如下宣告:
int? myNullableInt = 1;這兩個變數看起來似乎是一樣的。但事實並非如此。實際上,Nullable型別是一個結構體,它有兩個公開可讀欄位:HasValue和Value。HasValue是一個布林值,當有值儲存時它為真,當變數值為null時HasValue為假。當HavValue為真是時,可以取得變數的值;為假時,當嘗試取得變數的值時會丟擲一個異常。
現在null是C#的一個關鍵字,它可以被賦給一個Nullable型變數。下面是對Nullable型變數賦值的兩種有效方式。
double? myDouble = 3.14159;double? myOtherDouble = null;
可以看到,myDouble被賦給一個值,它也可以被賦以null。在第二個語句中,myOtherDouble被初始化為null——在一個非Nullable型變數中這樣做會產生異常。
使用nullable型別
一個Nullable型變數可以像一般值型別那樣使用。在編譯過程中Nullable型變數和非Nullable型變數會進行隱式田轉換。就是說我們可以把一個標準整型賦給一個整型Nullable變數,反之亦然。參考下面示例程式碼:
int? nFirst = null;
int
Second = 2; nFirst = Second;
// 可以
nFirst = 123;
// 可以
Second = nFirst;
//也可以,因為此時nFirst==123 nFirst = null;
// 可以
Second = nFirst;
// 丟擲異常, Second 是一個非nullable型變數。
可以看到,只要一個Nullable型變數的值不是null,它就可以和一個非Nullable型變數交換變數的值。如果包含null值,
就會丟擲異常。為避免異常發生,可以利用Nullable型變數的HasValue屬性。 if (nFirst.HasValue) Second = nFirst;
如上所示,如果nFirst 含有一個值,這個賦值語句就會執行;否則,就會跳過。
在Nullable值中使用操作符:Lifed Operators【1】
兩個相同型別的Nullable型和非Nullable型變數除了可以相互自動轉化之外,還可以通過操作符在它們中進行操作。參考下面程式碼:
int ValA = 10;
int? ValB = 3;int? ValC = ValA * ValB;
//ValC==30 int ValA = 10;
int? ValB = null;int? ValC = ValA * ValB;
//ValC==null int ValA = 10;
int? ValB = null;int? ValC = ValA + ValB;
//ValC仍然是null;
可以看到,兩個運算元只要有任何一個是null,得到的結果也一定是null,不管是加減還是乘除。當然,如果運算元不是null ,則結果還是按原來操作符運算得到的結果。
在上面的程式碼中,如果ValC不是Nullable型別,情況會怎麼樣呢?如以下程式碼:int ValA = 10;
int? ValB = 3;int ValC = ValA * ValB;
// ValC 不是Nullable型別上面這段程式碼會丟擲一個異常。ValA * ValB的結果是null,它不能被賦給一個非Nullable變數ValC。因為,會產生異常。 關係運算
兩個都是null值的Nullable變數被認為是相等的,而一個值為null的變數和其它任何非null值的變數都是不相等的。如下面示例程式碼:
在其它關係運算中,如果其中一個或兩個運算元為null,則結果一定是false。如下面示例程式碼(仍然使用上面定義的變數): Comparison
Result
移除空值
C#2.0同時也提供一個新操作符’??’用來合併空值。其語法格式如下:
returnValue = first ?? second;
在這個語句中,如果first為非null,則first的值會被賦給returnValue;如果first為null,則second會被賦給returnValue。注:returnValue可以是Nullable型別也可以是非Nullable型別。 如果要將一個Nullable變數的值賦給一個非Nullable變數,可以用下面方法:
int? ValA= 123;
int? ValB = null;
定義一個nullable型別非常類似於定義一個非nullable型別。不同之處在於使用型別修飾符“?”。比如定義一個整型如下:
int myInt = 1;要使一個整型變數可以儲存一個null值,可以如下宣告:
int? myNullableInt = 1;這兩個變數看起來似乎是一樣的。但事實並非如此。實際上,Nullable型別是一個結構體,它有兩個公開可讀欄位:HasValue和Value。HasValue是一個布林值,當有值儲存時它為真,當變數值為null時HasValue為假。當HavValue為真是時,可以取得變數的值;為假時,當嘗試取得變數的值時會丟擲一個異常。
現在null是C#的一個關鍵字,它可以被賦給一個Nullable型變數。下面是對Nullable型變數賦值的兩種有效方式。
double? myDouble = 3.14159;double? myOtherDouble = null;
可以看到,myDouble被賦給一個值,它也可以被賦以null。在第二個語句中,myOtherDouble被初始化為null——在一個非Nullable型變數中這樣做會產生異常。
使用nullable型別
一個Nullable型變數可以像一般值型別那樣使用。在編譯過程中Nullable型變數和非Nullable型變數會進行隱式田轉換。就是說我們可以把一個標準整型賦給一個整型Nullable變數,反之亦然。參考下面示例程式碼:
int? nFirst = null;
int
Second = 2; nFirst = Second;
// 可以
nFirst = 123;
// 可以
Second = nFirst;
//也可以,因為此時nFirst==123 nFirst = null;
// 可以
Second = nFirst;
// 丟擲異常, Second 是一個非nullable型變數。
可以看到,只要一個Nullable型變數的值不是null,它就可以和一個非Nullable型變數交換變數的值。如果包含null值,
就會丟擲異常。為避免異常發生,可以利用Nullable型變數的HasValue屬性。 if (nFirst.HasValue) Second = nFirst;
如上所示,如果nFirst 含有一個值,這個賦值語句就會執行;否則,就會跳過。
在Nullable值中使用操作符:Lifed Operators【1】
兩個相同型別的Nullable型和非Nullable型變數除了可以相互自動轉化之外,還可以通過操作符在它們中進行操作。參考下面程式碼:
int ValA = 10;
int? ValB = 3;int? ValC = ValA * ValB;
//ValC==30 int ValA = 10;
int? ValB = null;int? ValC = ValA * ValB;
//ValC==null int ValA = 10;
int? ValB = null;int? ValC = ValA + ValB;
//ValC仍然是null;
可以看到,兩個運算元只要有任何一個是null,得到的結果也一定是null,不管是加減還是乘除。當然,如果運算元不是null ,則結果還是按原來操作符運算得到的結果。
在上面的程式碼中,如果ValC不是Nullable型別,情況會怎麼樣呢?如以下程式碼:int ValA = 10;
int? ValB = 3;int ValC = ValA * ValB;
// ValC 不是Nullable型別上面這段程式碼會丟擲一個異常。ValA * ValB的結果是null,它不能被賦給一個非Nullable變數ValC。因為,會產生異常。 關係運算
兩個都是null值的Nullable變數被認為是相等的,而一個值為null的變數和其它任何非null值的變數都是不相等的。如下面示例程式碼:
int abc = 123;
int xyz = 890;
int? def = null;
int? uvw = 123;
Comparison
Result
abc == xyz
// false
abc == def
// false
def == null
// true
abc == uvw
// true
uvw == null
// false
uvw != null
// true
在其它關係運算中,如果其中一個或兩個運算元為null,則結果一定是false。如下面示例程式碼(仍然使用上面定義的變數): Comparison
Result
abc > uvw
// false, they are equal
abc < def
// false, def is null
uvw < def
// false, because def is null
def > null
// false, because right side is null
uvw > null
// false, because right side is null
移除空值
C#2.0同時也提供一個新操作符’??’用來合併空值。其語法格式如下:
returnValue = first ?? second;
在這個語句中,如果first為非null,則first的值會被賦給returnValue;如果first為null,則second會被賦給returnValue。注:returnValue可以是Nullable型別也可以是非Nullable型別。 如果要將一個Nullable變數的值賦給一個非Nullable變數,可以用下面方法:
int? ValA= 123;
int? ValB = null;
int NewVarA = ValA ?? -1;
int NewVarB = ValB ?? -1;
上面這段程式碼執行完以後,NewVarA的值為123,因為ValA的值不是null。而NewVarB值變為 -1,因為ValB為null。這就允許我們利用一個null值將一個變數轉變成一個預設值。在上面的程式碼中,這個預設值為 -1。
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/12639172/viewspace-462664/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- 瞭解下C# 可空型別(Nullable)C#型別Null
- 快速瞭解C# 8.0中“可空引用型別(Nullable reference type)”語言特性C#型別Null
- Kotlin可空型別與非空型別以及`lateinit` 的作用Kotlin型別
- C#8.0 可空引用型別C#型別
- 列舉型別在JPA中的使用型別
- JSON欄位型別在ORM中的使用JSON型別ORM
- 為你的專案啟用可空引用型別型別
- 如何將C# 7類庫升級到C# 8?使用可空引用型別C#型別
- python使用魔法函式建立可切片型別Python函式型別
- 原來C#的可空型別可以直接參與計算C#型別
- Swift 可選型別Swift型別
- C# 左移右移在資料型別轉換中的使用C#資料型別
- 在 Kotlin 中“實現”trait/型別類KotlinAI型別
- Flow靜態型別檢查及在Vue專案中的使用型別Vue
- 可變所有權型別型別
- java中判斷String型別為空和null的方法Java型別Null
- C#引用型別和值型別在堆、棧中的儲存C#型別
- Python語法--可變型別和不可變型別Python型別
- JS在if中的強制型別轉換JS型別
- 在例項中呼叫 Invoke 型別的類型別
- 自主資料型別:在TVM中啟用自定義資料型別探索資料型別
- 5種在TypeScript中使用的型別保護TypeScript型別
- Laravel 處理 MySQL geometry 空間型別LaravelMySql型別
- 安卓中的@Nullable和NonNull(NotNull) 等 註釋安卓Null
- 淺談 JavaScript 中 Array 型別的方法使用JavaScript型別
- Redis中 HyperLogLog資料型別使用總結Redis資料型別
- Java中的引用型別和使用場景Java型別
- double型別中可精確表達的最大正整數型別
- 2.5.9.2 重寫預設表空間型別型別
- 2.5.9.1 指定預設表空間的型別型別
- 在K8S中,Service的型別有哪些?K8S型別
- 修改全域性變數時,可變型別和不可變型別的區別變數型別
- 阿里為何禁止在物件中使用基本資料型別阿里物件資料型別
- java高階用法之:在JNA中使用型別對映Java型別
- 在 Solidity 中將地址型別轉換為 IERC20 介面型別Solid型別
- Java中的泛型程式設計:深入理解型別引數與型別邊界的使用Java泛型程式設計型別
- CATIA軟體許可型別全解析型別
- 靜態型別在 JavaScript 中是一種負擔嗎?型別JavaScript
- 可變資料型別(mutable)與不可變資料型別(immutable)總結資料型別