上一篇
判断Java对象是否为空,主要依据对象引用是否为null,对于字符串、集合等特定类型,还需检查内容是否为空(如字符串长度0或集合无元素),常用方法包括直接判null、使用工具类如Apache Commons Lang的ObjectUtils.isEmpty()。
在Java开发中,判断对象是否为空是避免NullPointerException的关键操作,以下是系统化的判断指南,涵盖基础类型、集合、字符串及自定义对象,结合代码示例与最佳实践:
基础判空:null检查
所有Java对象的初始空状态均可用判断:
Object obj = null;
if (obj == null) {
System.out.println("对象为null");
}
字符串空判断:双重验证
字符串需同时处理null和():

String str = "";
if (str == null || str.isEmpty()) { // Java 6+
System.out.println("字符串为空");
}
高效工具类(推荐):
import org.apache.commons.lang3.StringUtils;
if (StringUtils.isEmpty(str)) { // 同时检查null和空字符串
System.out.println("字符串为空");
}
集合判空:检查null与空集合
集合(List/Map/Set)需验证容器本身和内容:

List<String> list = new ArrayList<>();
if (list == null || list.isEmpty()) {
System.out.println("集合为空");
}
工具类优化:
import org.apache.commons.collections4.CollectionUtils;
if (CollectionUtils.isEmpty(list)) { // 支持null和size=0
System.out.println("集合为空");
}
数组判空:长度检查
String[] array = new String[0];
if (array == null || array.length == 0) {
System.out.println("数组为空");
}
自定义对象判空策略
重写isEmpty()方法
class User {
private String name;
private int age;
public boolean isEmpty() {
return name == null && age == 0;
}
}
User user = new User();
if (user.isEmpty()) { ... }
使用Optional(Java 8+)
Optional<User> optionalUser = Optional.ofNullable(user);
if (optionalUser.isEmpty()) { // 或 !optionalUser.isPresent()
System.out.println("对象为null");
}
级联判空(复杂对象)
if (user != null
&& user.getAddress() != null
&& user.getAddress().getCity() != null) {
// 安全操作
}
Optional高级用法:链式处理
避免多层if嵌套,提升可读性:

String cityName = Optional.ofNullable(user)
.map(User::getAddress)
.map(Address::getCity)
.orElse("Unknown"); // 若任意环节为null,返回默认值
常见误区与风险
- 错误示例:
if (obj.equals(null)) { ... } // 若obj为null,抛出NullPointerException - 集合操作:
list.size() == 0; // 若list为null,触发异常
- 未初始化对象:
Object obj; // 未赋初值,直接判空会导致编译错误
最佳实践总结
| 场景 | 推荐方法 | 工具支持 |
|---|---|---|
| 通用对象 | obj == null |
原生支持 |
| 字符串 | StringUtils.isEmpty(str) |
Apache Commons Lang |
| 集合/Map | CollectionUtils.isEmpty(collection) |
Apache Commons Collections |
| 链式安全访问 | Optional链式调用 |
Java 8+ |
| 自定义对象 | 重写isEmpty()逻辑 |
业务定制 |
关键原则:
- 对外部传入的参数始终做
null检查- 返回空集合而非
null(使用Collections.emptyList())- 优先使用
Optional减少嵌套
引用说明
- Oracle Java文档:
Optional类 - Apache Commons Lang:
StringUtils - 《Effective Java》第3版:条目55 “返回空集合而非null”
通过系统化判空策略,可显著提升代码健壮性,减少运行时异常,建议项目中统一工具类标准,并强制进行代码审查中的空安全检查。
