Map排序工具类如下:
import java.util.HashMap;
import java.util.LinkedHashMap;
import java.util.List;
import java.util.Map;
import java.util.stream.Collectors;
/**
* @author 睡竹
*/
public class MapSort {
/**
* 根据map中的value大小进行排序【由大到小】
*/
public static <K extends Comparable,V extends Comparable> Map<K, V> sortMapByValues(Map<K, V> map){
//需要用LinkedHashMap排序
HashMap<K, V> finalMap = new LinkedHashMap<K, V>();
//取出map键值对Entry<K,V>,然后按照值排序,最后组成一个新的列表集合
List<Map.Entry<K, V>> list = map.entrySet()
.stream()
//sorted((p2,p1) 表示由大到小排序 || sorted((p1,p2) 表示由小到大排序
.sorted((p2,p1)->p1.getValue().compareTo(p2.getValue()))
.collect(Collectors.toList());
//遍历集合,将排好序的键值对Entry<K,V>放入新的map并返回。
list.forEach(ele->finalMap.put(ele.getKey(), ele.getValue()));
return finalMap;
}
}
案例:
public static void main(String[] args) {
//创建map及数据
Map<String, Double> map = new HashMap<>();
map.put("张三", 98.5);
map.put("赵六", 66.0);
map.put("李四", 88.5);
map.put("王五", 95.2);
System.out.println("未排序前的map:" + map);
//排序
Map<String, Double> sortMap = MapSort.sortMapByValues(map);
System.out.println("已排序后的map:" + sortMap);
}
运行结果:
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/99584.html