1)首先,null是關鍵字,像public、static、final。它是大小寫敏感的,你不能將null寫成Null或NULL,編譯器將不能識別它們然后報錯。
2)就像每種基本類型都有默認值一樣,如int默認值為0,boolean的默認值為false,null是任何引用類型的默認值,不嚴格的說是所有object類型的默認值。就像你創建了一個布爾類型的變量,它將false作為自己的默認值,Java中的任何引用變量都將null作為默認值。這對所有變量都是適用的,如成員變量、局部變量、實例變量、靜態變量(但當你使用一個沒有初始化的局部變量,編譯器會警告你)。為了證明這個事實,你可以通過創建一個變量然后打印它的值來觀察這個引用變量。
3)我們要澄清一些誤解,null既不是對象也不是一種類型,它僅是一種特殊的值,你可以將其賦予任何引用類型,你也可以將null轉化成任何類型,來看下面的代碼:
String str =
null
;
Integer i =
null
;
Double d =
null
;
String myStr = (String)
null
;
Integer myI = (Integer)
null
;
Double myD = (Double)
null
;
4)null可以賦值給引用變量,你不能將null賦給基本類型變量,例如int、double、float、boolean。編譯器將會報錯。
5) 任何含有null值的包裝類在Java拆箱生成基本數據類型時候都會拋出一個空指針異常。一些程序員犯這樣的錯誤,他們認為自動裝箱會將null轉換成各自基本類型的默認值,例如對於int轉換成0,布爾類型轉換成false,但是那是不正確的,如下面所示:
Integer iAmNull =
null
;
int
i = iAmNull;
// Remember - No Compilation Error
public static void main(String args[]) throws InterruptedException { Map numberAndCount = new HashMap<>(); int[] numbers = {3, 5, 7,9, 11, 13, 17, 19, 2, 3, 5, 33, 12, 5}; for(int i : numbers){
int count = (int) numberAndCount.get(i);//NullPointerException numberAndCount.put(i, count++); } } }
package test;
import java.util.HashMap;
import java.util.Map;
public class Test3 {
public static void main(String args[]) throws InterruptedException {
Map numberAndCount = new HashMap<>();
Integer[] numbers = {3, 5, 7,9, 11, 13, 17, 19, 2, 3, 5, 33, 12, 5};
for(Integer i : numbers){
Integer count = (Integer) numberAndCount.get(i);
numberAndCount.put(i, count++); // NullPointerException
}
}
}
這段代碼看起來非常簡單並且沒有錯誤。你所做的一切是找到一個數字在數組中出現了多少次,這是Java數組中典型的尋找重復的技術。開發者首先得到以前的數值,然后再加一,最后把值放回Map里。程序員可能會以為,調用put方法時,第一種方式是轉換int報空指針,驗證之前說的。第二種方式,自動裝箱會自己處理好拆裝箱問題,但是忘記了當一個數字沒有計數值的時候,get方法返回null,而不是0,因為Integer的默認值是null而不是0。當把null值傳遞給一個int型變量的時候自動裝箱將會返回空指針異常。
6)如果使用了帶有null值的引用類型變量,instanceof操作將會返回false
Integer iAmNull = null; if(iAmNull instanceof Integer){ System.out.println("iAmNull is instance of Integer"); }else{ System.out.println("iAmNull is NOT an instance of Integer"); }
這是instanceof操作一個很重要的特性,使得對類型強制轉換檢查很有用
7)你可能知道不能調用非靜態方法來使用一個值為null的引用類型變量。它將會拋出空指針異常,但是你可能不知道,你可以使用靜態方法來使用一個值為null的引用類型變量。因為靜態方法使用靜態綁定,不會拋出空指針異常。下面是一個例子:
public class Testing { public static void main(String args[]){ Testing myObject = null; myObject.iAmStaticMethod(); myObject.iAmNonStaticMethod(); } private static void iAmStaticMethod(){ System.out.println("I am static method, can be called by null reference"); } private void iAmNonStaticMethod(){ System.out.println("I am NON static method, don't date to call me by null"); }
8)你可以將null傳遞給方法使用,這時方法可以接收任何引用類型,例如public void print(Object obj)可以這樣調用print(null)。從編譯角度來看這是可以的,但結果完全取決於方法。Null安全的方法,如在這個例子中的print方法,不會拋出空指針異常,只是優雅的退出。如果業務邏輯允許的話,推薦使用null安全的方法。
9)你可以使用==或者!=操作來比較null值,但是不能使用其他算法或者邏輯操作,例如小於或者大於。在Java中null==null將返回true。
參考資料:
http://www.importnew.com/14229.html