首先定义Map并且赋值。
Map<String, Integer> map = new HashMap<String, Integer>();
/*
Collections.sort(list, new PriceComparator())
- 参数一:需要排序的list
- 参数二:比较器,实现Comparator接口的类,返回一个int型的值,就相当于一个标志,告诉sort方法按什么顺序来对list进行排序。
Comparator是个接口,可重写compare()及equals()这两个方法,用于比较功能;如果是null的话,就是使用元素的默认顺序,如a,b,c,d,e,f,g,就是a,b,c,d,e,f,g这样,当然数字也是这样的。
- compare(a,b)方法:根据第一个参数小于、等于或大于第二个参数分别返回负整数、零或正整数。
- equals(obj)方法:仅当指定的对象也是一个 Comparator,并且强行实施与此 Comparator 相同的排序时才返回 true。
*/
定义一个list,并且把map存进去
List<Map.Entry<String, Integer>> list = new ArrayList<Map.Entry<String, Integer>>();for (Map.Entry<String, Integer> entry : list) {
//排序
private static class ValueComparator implements Comparator<Map.Entry<String, Integer>> {
文章来源: map如何进行排序,并且取排序后的前三数据