java hashmap最大值_使用Java 8 Streams,如何在HashMap中查找给定元素的最大值

第一个问题是,由于您希望按价格找到最大产品,因此最好使用items.values()作为流的来源,然后您将拥有Stream< Product>而不是Stream< Map.Entry< Integer,Product>>.

其次,reduce操作没有正确的类型.因此,要使当前代码正常工作,您需要执行以下操作:

Optional> result =

items.entrySet()

.stream()

.reduce((Map.Entry a, Map.Entry b) ->

a.getValue().getPrice() < b.getValue().getPrice() ? b : a);

return result.isPresent() ? result.get().getValue() : null;

第三,reduce操作的这种重载返回Optional< T>.所以结果集的接收者类型必须是Optional< T>如上所示.

在上面,我们在Optional中没有值的情况下返回null.

一个更好的解决方案是使方法返回一个类型Optional< Product>.这将向您或您的同事以及您的方法的所有未来用户提供文档,其中可能会给出结果为空的值.

这是一个更好的替代方法,可以在文档中返回null,并确保此方法的用户安全地解包返回值.

无效在某些时候可能是危险的,并且在适当的情况下利用Optional可以带您走很长的路.

考虑到所有这些,您的代码将成为:

// example without returning an `Optional`

public Product getMostExpensiveProduct(HashMap items) {

Optional maxPriceProduct =

items.values()

.stream()

.reduce((Product a, Product b) ->

a.getPrice() < b.getPrice() ? b : a);

return maxPriceProduct.orElse(null);

}

//示例返回一个Optional< T>

public Optional getMostExpensiveProduct(HashMap items) {

Optional maxPriceProduct =

items.values()

.stream()

.reduce((Product a, Product b) ->

a.getPrice() < b.getPrice() ? b : a);

return maxPriceProduct;

}

无论如何,max方法更适合于此任务而不是reduce,因此可以将其全部改进为:

Optional maxPriceProduct =

items.values()

.stream()

.max(Comparator.comparingInt(Product::getPrice));

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值