首页 > 基础资料 博客日记
java map 快速根据value排序
2024-11-01 20:00:06基础资料围观54次
文章java map 快速根据value排序分享给大家,欢迎收藏Java资料网,专注分享技术知识
Java中Map通过value进行排序(value类型可以是字符串string)
主要思路:将待排序Map中的所有元素置于一个列表中,接着使用Collections的一个静态方法 sort(List list, Comparator<? super T> c) 来排序列表,同样是用比较器定义比较规则。排序后的列表中的元素再依次装入Map,为了肯定的保证Map中元素与排序后的List中的元素的顺序一致,使用了LinkedHashMap数据类型。
//Map根据value进行排序
public static Map<String, Integer> valueUpSort(Map<String, Integer> map) {
//map不能为空
if (map == null || map.isEmpty()) {
return null;
}
//定义一个LinkedHashMap
Map<String, Integer> sortedMap = new LinkedHashMap<String, Integer>();
List<Map.Entry<String, Integer>> entryList = new ArrayList<Map.Entry<String, Integer>>(map.entrySet());
//比较器
Collections.sort(entryList, new Comparator<Map.Entry<String, Integer>>() {
@Override
public int compare(Map.Entry<String, Integer> o1, Map.Entry<String, Integer> o2) {
//降序
return o2.getValue().compareTo(o1.getValue());
//升序
// return o2.getValue().compareTo(o1.getValue());
}
});
Iterator<Map.Entry<String, Integer>> iter = entryList.iterator();
Map.Entry<String, Integer> tmpEntry = null;
while (iter.hasNext()) {
tmpEntry = iter.next();
sortedMap.put(tmpEntry.getKey(), tmpEntry.getValue());
}
return sortedMap;
}
测试
public class Test{
public static void main(String[] args) {
Map<String, String> map = new HashMap<>();
map.put("key1", "2024-05-30 17:30:27");
map.put("key4", "2024-05-30 17:45:17");
map.put("key22", "2024-05-30 17:35:34");
map.put("key3", "2024-05-31 16:20:24");
Map<String, String> stringStringMap = valueUpSort(map);
System.out.println(stringStringMap);
}
}
//结果
{key3=2024-05-31 16:20:24, key4=2024-05-30 17:45:17, key22=2024-05-30 17:35:34, key1=2024-05-30 17:30:27}
文章来源:https://blog.csdn.net/qq_28229449/article/details/139495492
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:jacktools123@163.com进行投诉反馈,一经查实,立即删除!
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:jacktools123@163.com进行投诉反馈,一经查实,立即删除!
标签: