Java中的Null是什么?
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;
你可以看到在编译和运⾏时期,将null强制转换成任何引⽤类型都是可⾏的,在运⾏时期都不会抛出空指针异常。
4)null可以赋值给引⽤变量,你不能将null赋给基本类型变量,例如int、double、float、boolean。编译器将会报错。
正如你看到的那样,当你直接将null赋值给基本类型,会出现编译错误。但是如果将null赋值给包装类object,然后将object赋给各⾃的基本类型,编译器不会报,但是你将会在运⾏时期遇到空指针异常。这是Java中的⾃动拆箱导致的。
5)任何含有null值的包装类在Java拆箱⽣成基本数据类型时候都会抛出⼀个空指针异常。⼀些程序员犯这样的错误,他们认为⾃动装箱会将null转换成各⾃基本类型的默认值,例如对于int转换成0,布尔类型转换成false,但是那是不正确的,如下⾯所⽰:
Integer iAmNull = null;
int i = iAmNull; // Remember - No Compilation Error
但是当你运⾏上⾯的代码⽚段的时候,你会在控制台上看到主线程抛出空指针异常。在使⽤HashMap和Integer键值的时候会发⽣很多这样的错误。当你运⾏下⾯代码的时候就会出现错误。
public class Test3 {
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) (i);//NullPointerException
numberAndCount.put(i, count++);
}
}nullpointerexception为什么异常
}
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) (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。
参考资料:
www.importnew/14229.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论