作者:品味a江湖_232_466 | 来源:互联网 | 2022-12-19 18:16
当我尝试使用computeIfPresent()方法更改Map 时,在使用innerMap时我无法实现此方法.
这有效:
Map mapOne= new HashMap<>();
mapOne.computeIfPresent(key, (k, v) -> v + 1);
这不起作用:
Map> mapTwo = new HashMap<>();
mapTwo.computeIfPresent(key, (k, v) -> v.computeIfPresent(anotherKey, (x, y) -> y + 1);
在第二个示例中,我收到以下错误消息:"lambda表达式中的错误返回类型:整数不能转换为Map
".我的IDE将v识别为Map.但是这个功能不起作用.
显然该方法返回一个Integer,但是我没有看到它与第一个没有Innermap的方法的区别.到目前为止,我还没有在网上找到类似的案例.
我怎样才能让它发挥作用?
1> Eran..:
外部lambda表达式应该返回Map
引用的v
:
mapTwo.computeIfPresent(key,
(k, v) -> {
v.computeIfPresent(anotherKey, (x, y) -> y + 1);
return v;
});
它不能返回Integer
表达式的值v.computeIfPresent(anotherKey, (x, y) -> y + 1);
.
2> FilipRistic..:
为了理解您的问题,让我们看一下您正在使用的方法的签名:
V computeIfPresent(K key, BiFunction super K,? super V,? extends V> remappingFunction)
如您所见,它返回一个基于V
泛型参数的类型,该参数代表存储的值Map
.这是你面临问题的地方:你的内部地图存储Integer
,所以当你打电话时computeIfPresent
,你得到Integer
的外部地图需要另一个Map
.
编辑:
在写作的过程中,我意识到Eran已经给出了一个代码示例,它展示了如何做到这一点.
但是我会留下这个答案,因为它解释了为什么你的方法不起作用,所以它可能对某人有帮助.