Java TreeMap如何按照key或value降序排列呢?

java-教程王 Java教程 发布时间:2021-11-28 17:26:44 阅读数:15005 1
我们都知道TreeMap默认情况下是按照key升序排序,那么如何将value按照降序排列呢?
下文将一一道来,如下所示: 例:

//key进行降序排序
//构造函数中传入外部比较器
Map<String,String> map = new TreeMap<String,String>(new Comparator<String>(){ 
   public int compare(String obj1,String obj2){ 
    //降序排序 
    return obj2.compareTo(obj1); 
   } 
}); 
map.put("one", "1"); 
map.put("two", "2"); 
map.put("a", "3"); 
Set<String> keySet = map.keySet(); 
Iterator<String> iter = keySet.iterator(); 
while(iter.hasNext()){ 
    String key = iter.next(); 
    System.out.println(key+":"+map.get(key)); 
}

//value进行降序排列
//自定义一个list,用于存放value值,然后传入比较器对value值进行比较
List<Map.Entry<String,String>> mappingList = null; 
Map<String,String> map2 = new TreeMap<String,String>(); 
map2.put("1","one"); 
map2.put("2","two"); 
map2.put("3","a"); 

//借助ArrayList构造函数把map.entrySet()转换成list 
mappingList = new ArrayList<Map.Entry<String,String>>(map2.entrySet()); 
//通过比较器实现比较排序 
Collections.sort(mappingList, new Comparator<Map.Entry<String,String>>(){ 
  public int compare(Map.Entry<String,String> mapping1,Map.Entry<String,String> mapping2){  
      return mapping1.getValue().compareTo(mapping2.getValue()); 
  }
});
for(Map.Entry<String,String> mapping:mappingList){  
    System.out.println(mapping.getKey()+":"+mapping.getValue()); 
}
版权声明

本文仅代表作者观点,不代表本站立场。
本文系作者授权发表,未经许可,不得转载。

本文链接: https://www.Java265.com/JavaCourse/202111/1898.html

最近发表

热门文章

好文推荐

Java265.com

https://www.java265.com

站长统计|粤ICP备14097017号-3

Powered By Java265.com信息维护小组

使用手机扫描二维码

关注我们看更多资讯

java爱好者