Дми*_*лев 14 java lambda dictionary comparator java-8
我一直在尝试使用lambda表达式在Java8中创建Map.Entry Comparator,并且发现了一种非常奇怪的行为.
Map<Integer, String> map = new TreeMap<>();
map.put(1, "Hello");
map.put(3, "zzzz");
map.put(2, "aaaa");
map.put(5, "AAAAA");
map.put(4, "aaaa");
Comparator<Map.Entry<Integer, String>> com = Comparator.comparing(Map.Entry::getValue);
com = com.reversed();
Comparator<Map.Entry<Integer, String>> com2 = Comparator.comparing(Map.Entry::getValue).reversed();
Run Code Online (Sandbox Code Playgroud)
com工作正常,但com2包含一个错误的" 无法解析方法getValue ".我真的不知道为什么?有什么建议?
PS有没有办法避免用Integer,String键入Map.Entry?任何更短的方式?
Tag*_*eev 24
从Java-8开始,有一个独立的方法Entry.comparingByValue可以代替使用:
Comparator<Map.Entry<Integer, String>> com2 =
Map.Entry.<Integer, String>comparingByValue().reversed();
Run Code Online (Sandbox Code Playgroud)
另一种方法是传递参数:
Comparator<Map.Entry<Integer, String>> com2 =
Map.Entry.comparingByValue(Comparator.reverseOrder());
Run Code Online (Sandbox Code Playgroud)
这种方式类型参数是不必要的.
Jon*_*eet 14
当前您在指定方法引用时指定原始类型 - 在第一种情况下,赋值的泛型类型推断告诉编译器您的意思,但这对方法调用的目标不起作用.您可以指定方法引用的泛型类型:
Comparator<Map.Entry<Integer, String>> com2 =
Comparator.comparing(Map.Entry<Integer,String>::getValue).reversed();
Run Code Online (Sandbox Code Playgroud)
(我意识到你的代码需要增加你需要的次数Map.Entry<Integer, String>,但不幸的是,这里很难避免.)