我们从一个简单的用例开始。在 Java 8 之前,任何访问对象方法或属性的调用都可能导致 NullPointerException:
String isocode = user.getAddress().getCountry().getIsocode().toUpperCase();
如果是Optional的话,可以这样,不用每个都判断,
User user= new User("anna@gmail.com", "1234");
String result=Optional.ofNullable(user)
.flatMap(u->u.getAddress())
.flatMap(a->a.getCountry())
.map(c->c.getIsocode())
.orElse("default");
也就是说如果放在Optional里面的话,不需要判断 是否为空,
(1)因为如果user 会返回 default,不会抛出空指针异常
(2)如果user不为空,但是address为空的话,也 会返回 default,不会抛出空指针异常
(3)如果user不为空,而且address不为空,但是country为空的话,也 会返回 default,不会抛出空指针异常
(4)如果user不为空,而address为空的话,country也不为空,但是 iscode为空的话,也 会返回 default,不会抛出空指针异常
这是我们项目中用到的:
Optional advanceDOOptional =appealAdvanceService.getByOrderId(orderId);return advanceDOOptional.map(AppealAdvanceDO::getAppealId).orElse(0L);
在这个小示例中,如果我们需要确保不触发异常,就得在访问每一个值之前对其进行明确地检查:
if (user != null) {
Address address=user.getAddress();if (address != null) {
Country country=address.getCountry();if (country != null) {
String isocode=country.getIsocode();if (isocode != null) {
isocode=isocode.toUpperCase();
}
}
}
}
你看到了,这很容易就变得冗长,难以维护。
为了简化这个过程,我们来看看用 Optional 类是怎么做的。从创建和验证实例,到使用其不同的方法,并与其它返回相同类型的方法相结合,下面是见证 Optional奇迹的时刻。