一、理论基点
Map是键值对的集合接口,它的实现类主要包括:HashMap,TreeMap,Hashtable以及LinkedHashMap等。
TreeMap:基于红黑树(Red-Black-Tree)的NavigableMap实现,该映射根据其键的自然顺序进行排序,或者根据创建映射时提供的Comparator进行排序,具体取决于使用的构造方法。
HashMap的值是没有顺序的,它是按照key的hashCode来实现的,对于这个无序的HashMap我们要如何实现排序呢? 参照TreeMap的value排序。
Map.Entry返回Collections视图。
二、TreeMap按照key排序
TreeMap默认是升序的,如果我们需要改变排序方式,则需要使用比较器:Comparator。Comparator可以对集合对象或者数组进行排序的比较器接口,实现该接口的public compare(T o1,To2)
方法即可实现排序,如下:
import java.util.Comparator; import java.util.TreeMap; public class TestCd { private static void sortByKeyDesc(){ TreeMap<String, String> tm=new TreeMap<String, String>(new Comparator<String>() { @Override public int compare(String o1, String o2) { return o2.compareTo(o1); } }); tm.put("a", "ddd"); tm.put("b", "ccc"); tm.put("c", "bbb"); tm.put("d", "aaa"); for (String key : tm.keySet()) { System.out.println("key :"+key+",對應的value:"+tm.get(key)); } } public static void main(String[] args) { sortByKeyDesc(); }
运行结果如下:
key :d,對應的value:aaa
key :c,對應的value:bbb
key :b,對應的value:ccc
key :a,對應的value:ddd
三、TreeMap按照value排序
上面的例子是根据TreeMap的可以值来进行排序的,但是有时我们需要根据TreeMap的value来进行排序。对于value排序我们就需要借助于Collection的sort(List<T> list,Comparator<?super T>c)方法,该方法根据指定比较器产生的顺序对指定列表进行排序。但是有一个前提,那就是所有的元素都必须能够根据所提供的比较器来进行比较,如下:
import java.util.ArrayList; import java.util.Collections; import java.util.Comparator; import java.util.List; import java.util.Map; import java.util.Map.Entry; import java.util.TreeMap; public class TestCd { private static void sortByValueDesc(){ Map<String, String> tm=new TreeMap<String, String>(); tm.put("a", "ddd"); tm.put("b", "ccc"); tm.put("c", "bbb"); tm.put("d", "aaa"); //这里将map.entrySet()转换成list List<Map.Entry<String,String>> list = new ArrayList<Map.Entry<String,String>>(tm.entrySet()); //然后通过比较器来实现排序 Collections.sort(list,new Comparator<Map.Entry<String,String>>() { //降序排序 @Override public int compare(Entry<String, String> o1, Entry<String, String> o2) { return o2.getValue().compareTo(o1.getValue()); } }); for(Map.Entry<String,String> mapping:list){ System.out.println(mapping.getKey()+":"+mapping.getValue()); } } public static void main(String[] args) { sortByValueDesc(); } }
运行结果:
a:ddd
b:ccc
c:bbb
d:aaa