java中空指针异常:NullPointerException出现的根本原因是在null对象上调用方法或属性了。
java中容易产生空指针异常:NullPointerException的场景,总结如下:
1.判断字符串是否为空
风险代码:
String str = null;
if (str.isEmpty()) { // 空指针异常
// 代码逻辑
}
修改后的代码:
String str = null;
if (str != null && str.isEmpty()) { // 无异常
// 代码逻辑
}
分析:字符串为null时,直接调用isEmpty方法就会报空指针异常。一种解决方案如上,先判断字符串是否为null,不为null再执行isEmpty方法。
2.字符串比较
风险代码:
String str = null;
if (str.equals("A")) { // 空指针异常
// 代码逻辑
}
修改后的代码:
String str = null;
if ("A".equals(str)) { // 无异常
// 代码逻辑
}
分析:字符串为null时,直接调用equals方法就会报空指针异常。一种解决方案如上,在常量上调用equals方法就可避免空指针异常。如果比较的两个字符串都是变量,那就只有先判断null,不为null再执行了。类似的场景还有:equalsIgnoreCase方法。
3.集合类添加元素
风险代码:
String str = null;
String value = null;
Hashtable<String, String> hashtable = new Hashtable<>();
hashtable.put(key, value); // 空指针异常
修改后的代码:
String key = null;
String value = null;
Hashtable<String, String> hashtable = new Hashtable<>();
if (key != null && value != null) {
hashtable.put(key, value); // 无异常
}
分析:部分集合中不允许设置key或value为null,这类集合主要有:Hashtable、ConcurrentHashMap、ConcurrentSkipListSet、ConcurrentLinkedDeque、ConcurrentLinkedQueue、LinkedBlockingDeque、LinkedBlockingQueue、ArrayBlockingQueue、PriorityBlockingQueue等。
4.判断集合是否为空
风险代码:
ArrayList array = null;
if (array.isEmpty()) { // 空指针异常
// 代码逻辑
}
修改后的代码:
ArrayList array = null;
if (array != null && array.isEmpty()) { // 无异常
// 代码逻辑
}
分析:集合在判空时与字符串判空类似,如果集合为null,直接调用isEmpty方法会报空指针异常。一种解决方案如上,先判断集合是否为null,不为null再执行isEmpty方法。数组的判空也是类似。
5.包装类自动拆箱
风险代码:
Integer integer = null;
int number = integer; // 空指针异常
修改后的代码:
Integer integer = null;
if (integer != null) {
int number = integer; // 无异常
}
分析:基础数据类型:boolean、byte、char、short、int、float、double、long的包装类:Boolean、Byte、Character、Short、Integer、Float、Double、Long在自动拆箱时会有空指针异常风险。所以在使用时必须先判断是否为null,不为null再使用。