JAVA 如何快速对Map进行按照Value排序 JAVA 中的TreeMap支持根据Key进行排序,默认为升序排序,可以传入比较器进行自定义排序,那如何根据Value进行排序呢
- 按照Key进行排序
Map<String,String> map = new TreeMap<>(new Comparator<String>(){
public int compare(String o1,String o2){
return o2.compareTo(o1);
}
});
复制代码 2. 按照Value进行排序
1.使用List进行排序
Map<String,String> map = new HashMap<>();
map.put("3","7");
map.put("2","5");
map.put("1","6");
List<Map.Entry<String,String>> list = new ArrayList<>(map.entrySet());
list.sort(Comparator.comparing(Map.Entry::getValue));
Map<String,String> map2 = new LinkedHashMap<>();
for(Map.Entry<String,String> entry: list){
map2.put(entry.getKey(), entry.getValue());
}
map2.forEach((o1, o2)-> System.out.println(o1+":"+o2));
复制代码 2.使用JAVA 8 Stream进行排序
Map<Integer, String> map = new HashMap<>();
map.put(1, "Tommy");
map.put(3, "Jerry");
map.put(2, "Catty");
map.values().stream().sorted().collect(Collectors.toList()).forEach(System.out::println);
map.values().stream().sorted(Comparator.reverseOrder()).collect(Collectors.toList())
.forEach(System.out::println);
对List<Map<String, Object>>进行排序,按map中某个键排序
第一种方法
第二种方法
Collections.sort(mapList,(x,y)-> ((String) x.get("vehicleNumber")).compareTo(((String) y.get("vehicleNumbe
r"))));
|