TreeMap 和 LinkedHashMap 的区别
时间: 2023-12-25 11:25:59 浏览: 96
TreeMap和LinkedHashMap都是Java中的Map实现,但它们有一些明显的区别:
1. TreeMap是基于红黑树实现的,而LinkedHashMap是基于哈希表和双向链表实现的。
2. TreeMap是有序的,而LinkedHashMap可以按照插入顺序或访问顺序进行排序。
3. TreeMap的键必须实现Comparable接口或者在构造函数中提供一个Comparator,而LinkedHashMap没有这个限制。
4. TreeMap的性能比LinkedHashMap略低,因为它需要维护红黑树的平衡性。
下面是一个使用TreeMap的例子:
```
import java.util.Map;
import java.util.TreeMap;
public class Test {
public static void main(String[] args) {
Map<String, String> treeMap = new TreeMap<>();
treeMap.put("key1", "value1");
treeMap.put("key3", "value3");
treeMap.put("key2", "value2");
treeMap.put("key4", "value4");
for (Map.Entry<String, String> entry : treeMap.entrySet()) {
String key = entry.getKey();
String value = entry.getValue();
System.out.println("key:" + key + ",value:" + value);
}
}
}
```
阅读全文