TreeMap用法总结

简介: TreeMap用法总结

持续创作,加速成长!这是我参与「掘金日新计划 · 10 月更文挑战」的第18天

TreeMap中的元素默认按照keys的自然排序排列。

(对Integer来说,其自然排序就是数字的升序;对String来说,其自然排序就是按照字母表排序)

构造函数 TreeMap():创建一个空TreeMap,keys按照自然排序

TreeMap<Integer, String> treeMap = new TreeMap<>(); TreeMap(Comparator comparator):创建一个空TreeMap,按照指定的comparator排序

TreeMap<Integer, String> map = new TreeMap<>(Comparator.reverseOrder()); map.put(3, "val"); map.put(2, "val"); map.put(1, "val"); map.put(5, "val"); map.put(4, "val"); System.out.println(map); // {5=val, 4=val, 3=val, 2=val, 1=val} TreeMap(Map m)

由给定的map创建一个TreeMap,keys按照自然排序

Map<Integer, String> map = new HashMap<>(); map.put(1, "val"); ... TreeMap<Integer, String> treeMap = new TreeMap<>(map); TreeMap(SortedMap m)

由给定的有序map创建TreeMap,keys按照原顺序排序

常用方法 增添元素 V put(K key, V value):将指定映射放入该TreeMap中 V putAll(Map map):将指定map放入该TreeMap中 删除元素 void clear():清空TreeMap中的所有元素 V remove(Object key):从TreeMap中移除指定key对应的映射 修改元素 V replace(K key, V value):替换指定key对应的value值 boolean replace(K key, V oldValue, V newValue):当指定key的对应的value为指定值时,替换该值为新值 查找元素 boolean containsKey(Object key):判断该TreeMap中是否包含指定key的映射 boolean containsValue(Object value):判断该TreeMap中是否包含有关指定value的映射 Map.Entry<K, V> firstEntry():返回该TreeMap的第一个(最小的)映射 K firstKey():返回该TreeMap的第一个(最小的)映射的key Map.Entry<K, V> lastEntry():返回该TreeMap的最后一个(最大的)映射 K lastKey():返回该TreeMap的最后一个(最大的)映射的key v get(K key):返回指定key对应的value SortedMap<K, V> headMap(K toKey):返回该TreeMap中严格小于指定key的映射集合 SortedMap<K, V> subMap(K fromKey, K toKey):返回该TreeMap中指定范围的映射集合(大于等于fromKey,小于toKey) 遍历接口 Set<Map<K, V>> entrySet():返回由该TreeMap中的所有映射组成的Set对象 void forEach(BiConsumer<? super K,? super V> action):对该TreeMap中的每一个映射执行指定操作 Collection values():返回由该TreeMap中所有的values构成的集合 其他方法 Object clone():返回TreeMap实例的浅拷贝 Comparator<? super K> comparator():返回给该TreeMap的keys排序的comparator,若为自然排序则返回null int size():返回该TreepMap中包含的映射的数量

TreeMap<Integer, String> treeMap = new TreeMap<>(); treeMap.put(1, "a"); treeMap.put(2, "b"); treeMap.put(3, "c"); treeMap.put(4, "d"); // treeMap: {1=a, 2=b, 3=c, 4=d}
treeMap.remove(4); // treeMap: {1=a, 2=b, 3=c} int sizeOfTreeMap = treeMap.size(); // sizeOfTreeMap: 3
treeMap.replace(2, "e"); // treeMap: {1=a, 2=e, 3=c}
Map.Entry entry = treeMap.firstEntry(); // entry: 1 -> a Integer key = treeMap.firstKey(); // key: 1 entry = treeMap.lastEntry(); // entry: 3 -> c key = treeMap.lastKey(); // key: 3 String value = treeMap.get(3); // value: c SortedMap sortedMap = treeMap.headMap(2); // sortedMap: {1=a} sortedMap = treeMap.subMap(1, 3); // sortedMap: {1=a, 2=e}
Set setOfEntry = treeMap.entrySet(); // setOfEntry: [1=a, 2=e, 3=c] Collection values = treeMap.values(); // values: [a, e, c] treeMap.forEach((integer, s) -> System.out.println(integer + "->" + s)); // output: // 1 -> a // 2 -> e // 3 -> c

遍历方式 for循环

for (Map.Entry entry : treeMap.entrySet()) { System.out.println(entry); } 迭代器循环
Iterator iterator = treeMap.entrySet().iterator(); while (iterator.hasNext()) { System.out.println(iterator.next()); }

补充:如何选择合适的Map HashMap可实现快速存储和检索,但其缺点是其包含的元素是无序的,这导致它在存在大量迭代的情况下表现不佳。 LinkedHashMap保留了HashMap的优势,且其包含的元素是有序的。它在有大量迭代的情况下表现更好。 TreeMap能便捷的实现对其内部元素的各种排序,但其一般性能比前两种map差。 LinkedHashMap映射减少了HashMap排序中的混乱,且不会导致TreeMap的性能损失。

相关文章
|
存储 缓存 安全
Java集合框架(Map篇)
在这个示例代码中,首先定义了一个数组和一个集合,并使用Arrays.asList()方法将数组转换成集合。接着对数组和集合分别进行排序,使用binarySearch()方法查找元素位置,使用copyOf()和copy()方法复制数组和集合,最后输出结果。可以看到,Arrays和Collections提供的方法可以方便地对数组和集合进行操作,节省开发者的时间和精力。
|
3月前
|
算法 Java 程序员
Map - TreeSet & TreeMap 源码解析
Map - TreeSet & TreeMap 源码解析
57 0
|
存储 安全 Java
Java集合Map之HashMap常用操作
在我看来 , 链表是为了解决hash碰撞使用的一种方法 : 拉线法 , 而红黑树是为了解决&quot;拉的这个线&quot;(链表存储的元素太多)过长的话元素遍历慢的问题
70 2
|
7月前
|
Java
Java集合之map 集合使用
Java集合之map 集合使用
26 0
|
8月前
|
存储 设计模式 Java
|
存储 安全
集合框架系列(三)之 map双列集合
集合框架系列(三)之 map双列集合
|
存储 算法 Java
java集合框架Map之HashMap底层原理解析
阈值(threshold) = 负载因子(loadFactor) x 容量(capacity) , 当HashMap中的table数组(桶)的长度 >= 阈值的时候就会自动触发扩容机制
84 0
|
存储 Java
Java集合学习3:Set集合-TreeSet
基于hashcode计算元素存放位置。 当存入元素的哈希码相同时,会调用equals进行确认,如果为true,则拒绝后者存入。
Java集合学习3:Set集合-TreeSet
|
算法 Java 程序员