我有一个服务,可以从数据库中查询优惠券列表。该服务将Optional
返回给客户端。
return listOfCoupons.isEmpty() ? Optional.empty() : Optional.of(listOfCoupons.get(listOfCoupons.size() - 1));
并且此代码的客户端通过以下方式使用名为“优惠券”的Optional
:
if (coupons.isPresent) {
save (coupons.get());
}
这是Optional
的正确用法吗?
您对Optional<T>
API的使用在某种程度上看起来还不错,因为我看不到任何滥用。如果我要挑剔并建议我做点改变:
if (coupons.isPresent) {
save (coupons.get());
}
至:
coupons.ifPresent(c -> save(c)); //or method reference
但是再说一次,这真是令人难受。