map 的key排序
时间: 2023-09-05 20:07:35 浏览: 80
在 Java 中,`Map` 接口本身不维护键的顺序,但是可以使用 `TreeMap` 来实现按键进行排序的功能。`TreeMap` 是 `Map` 接口的一个实现类,它根据键的自然顺序或者通过提供的 `Comparator` 接口进行排序。
下面是一个示例代码,展示如何使用 `TreeMap` 对键进行排序:
```java
import java.util.Map;
import java.util.TreeMap;
public class Main {
public static void main(String[] args) {
// 创建一个 TreeMap 对象
Map<String, Integer> sortedMap = new TreeMap<>();
// 向 TreeMap 添加键值对
sortedMap.put("c", 3);
sortedMap.put("a", 1);
sortedMap.put("b", 2);
// 遍历 TreeMap 输出排序后的键值对
for (Map.Entry<String, Integer> entry : sortedMap.entrySet()) {
System.out.println(entry.getKey() + ": " + entry.getValue());
}
}
}
```
运行以上代码,输出结果为:
```
a: 1
b: 2
c: 3
```
可以看到,`TreeMap` 对键进行了排序,按照字母顺序输出了键值对。你可以根据需要自定义比较器来实现自定义排序规则。
阅读全文