在Java开发的旅程中,有一个古老而又常见的敌人总是悄然潜伏,那就是NullPointerException(简称NPE)。无论是新手程序员还是经验丰富的开发者,几乎都曾被这个问题困扰过。它不仅让我们的程序在运行时崩溃,还可能导致难以追踪的bug。尽管Java是一门严格类型的语言,但NPE却是一个绕不过去的难题。
那么,我们该如何应对这个挑战呢?在这篇博客中,我将带您了解一些处理NullPointerException的基础方法,以及Java 8引入的一些更优雅的解决方案。通过学习和应用这些技巧,您将能够编写出更健壮、更可靠的Java代码。
现在我们有以下的代码:
//角色
class Role {
private String roleDesc;
public Role(String roleDesc) {
this.roleDesc = roleDesc;
}
public String getRoleDesc() {
return roleDesc;
}
public void setRoleDesc(String roleDesc) {
this.roleDesc = roleDesc;
}
}
//用户
class User {
private Role role;
public User(Role role) {
this.role = role;
}
public Role getRole() {
return role;
}
public void setRole(Role role) {
this.role = role;
}
}
!= null
我们想通过User类来获取Role角色类中roleDesc信息的时候,通常需要做非空校验,预防程序发生NullPointerException
:
if (User != null && User.getRole() != null) {
System.out.println(User.getRole().roleDesc());
}
这就导致我们代码中,大量的出现!=null
影响代码的美观,也丢失了可读性。
Optional
java 8,是jdk的一个飞跃,即使现在jdk已经更新到23,但是大部分依然使用这java 8,盛传一句:你升任你升,我用java 8。java 8新增了Optional
可以帮助我们更加优雅的判空。
//项目中使用最多的就是直接对 返回对象做非空校验,然后返回一个boolean类型
Optional.ofNullable(User).isPresent();
//针对嵌套对象,我们也可以对其进行优雅的判空
Optional.ofNullable(User)
.map(User::getRole())
.map(Role::getRoleDesc)
.ifPresent(System.out::println);
每种方法都各有优劣,有人说 直接判空让别人更加的直观,但也有人讨厌。有人喜欢Optional的优雅,也有人不喜欢Optional的可读性。特别是情况复杂的时候,需要耗费一定的时间,才能理解代码。但无论怎样,都是我们进行判空的工具,选择自己喜欢的就好。