Map是键值对的集合接口,它的实现类主要包括:HashMap、Hashtable以及LinkedHashMap等。
Map.Entry返回Collections视图。
TreeMap默认是升序的,如果我们需要改变排序方式,则需要使用比较器:Comparator。Comparator可以对集合对象或者数组进行排序的比较器接口,实现该接口的public compare(T o1,To2)方法即可实现排序。
TreeMap默认按key升序排序
public class T0 {
public static void main(String[] args) {
TreeMap treeMap = new TreeMap<>();
treeMap.put(1, "a");
treeMap.put(3, "b");
treeMap.put(2, "c");
for (Map.Entry item :
treeMap.entrySet()) {
System.out.println(item);
}
Map.Entry entry = treeMap.firstEntry();
System.out.println("entry = " + entry);
}
} 修改TreeMap的排序方式,按key降序排序
实现方式是自定义Comparator,可以直接使用Comparator.reverseOrder()或者手动实现Comparator.
new TreeMap<>(Comparator.reverseOrder())
public class T1 {
public static void main(String[] args) {
Comparator keyComparator = new Comparator() {
@Override
public int compare(Integer o1, Integer o2) {
return o2.compareTo(o1);
}
};
TreeMap treeMap = new TreeMap(keyComparator);
treeMap.put(1, "a");
treeMap.put(3, "b");
treeMap.put(2, "c");
for (Map.Entry item :
treeMap.entrySet()) {
System.out.println(item);
}
Map.Entry entry = treeMap.firstEntry();
System.out.println("entry = " + entry);
}
} 以下只演示按TreeMap按Value升序排序,这同样适用于HashMap。
修改TreeMap的排序方式,按Value升序排序
注意:正常情况下Map是不可以使用Collections.sort()方法进行排序的,不过可以将Map转换成list之后再进行排序。
public class T2 {
public static void main(String[] args) {
Comparator> comparator = new Comparator>() {
@Override
public int compare(Map.Entry o1, Map.Entry o2) {
return o1.getValue().compareTo(o2.getValue());
}
};
TreeMap treeMap = new TreeMap<>();
treeMap.put(1, "a");
treeMap.put(9, "e");
treeMap.put(3, "b");
treeMap.put(2, "c");
ArrayList> list = new ArrayList>(treeMap.entrySet());
Collections.sort(list, comparator);
for (Map.Entry entry : list) {
System.out.println(entry);
}
}
} 本文由博客一文多发平台 OpenWrite 发布!