Java TreeMap如何按照key或value降序排列呢?
我们都知道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()); }
版权声明
本文仅代表作者观点,不代表本站立场。
本文系作者授权发表,未经许可,不得转载。