我有以下案例,我似乎不明白我应该如何正确处理它。假设以下域结构。我有一个存储联系人对象列表的客户对象。现在我想做以下事情:1) 尝试检索所述客户(可选)。2) 如果存在,则使用它来检索联系人对象。我当时的代码如下所示:Contact contact = customer.map(cust -> getContacts().stream()
.findFirst()
.orElse(null))
.orElse(null);请注意,客户对象已初始化为 Optional。现在我的问题如下:我想去掉这些orElse语句以简化代码,并根据所讨论的对象是否等于另一个对象简单地返回 true 或 false。到目前为止,我已经尝试过了,我认为这可以完成这项工作。return customer.map(cust -> getContacts()
.stream()
.findFirst()
.map(custContact -> custContact.map(contact::equals).orElse(false))
.orElse(false);我的主要问题是,这可以进一步简化吗?我想我在那些映射操作中遗漏了一些东西,但我不太确定。我的另一个解决方案是这个:return customer.map(cust -> getContacts()
.stream()
.findFirst()
.map(contact::equals).orElse(false))
.orElse(false);
1 回答

蝴蝶刀刀
TA贡献1801条经验 获得超8个赞
您可以Optional.filter()
使用Stream.anyMatch()
和Optional.isPresent()
:
customer.filter(cust -> getContacts().stream().anyMatch(contact::equals)).isPresent();
添加回答
举报
0/150
提交
取消