Java集合框架之TreeMap浅析

一、TreeMap综述:

TreeMap在Map中的结构如下:

TreeMap 实现了 SortedMap 和 NavigableMap 接口,所有本文还会记录 SortedMap 和 NavigableMap 的阅读笔记。

SortedMap

1. 排序的比较应该和 equals(Object) 保持一致

2. 应该提供四种“标准”的构造器

  1). 无参构造器

  2). 带一个 Comparator 为参数的构造器

  3). 带一个 Map 为参数的构造器

  4). 带一个 SortedMap 为参数的构造器

3.  subMap ,  headMap ,  tailMap ,  KeySet ,  values,  entrySet  等方法返回的 Map 或 Set 和 SortedMap 本身使用同一份数据,所以对 subMap 返回的 Map 进行修改,同样会反映到 SortedMap 上。

NavigableMap

1. lowerEntry, floorEntry, ceilingEntry, higherEntry 分别返回 小于、小于或等于,大于或等于,以及大于给定 key 的 Map.Entry。这类型的方法用于定位离目标给定值最近的元素。

2. 增长序 map 的操作比递减序的 map 的操作要快。

3. 返回 entry 的方法返回的是那一刻的 entry 快照,所以通常不支持 Entry.setValue 方法。

例如, TreeMap 实现 NavigableMap 的 firstEntry,返回会的就是根据给定 entry 的 key, value 新建的不可变

SimpleImmutableEntry 对象。

4. pollFirstEntry 删除并返回第一个元素

TreeMap

1. 基于红黑树(Red-Black tree)的 NavigableMap 实现。该映射根据其键的自然顺序进行排序,或者根据创建映射时提供的 Comparator 进行排序,具体取决于使用的构造方法。

2. 根据自然序,或者给定的比较器是内部元素保持有序。

3. 提供复杂度为 log(n) 的 containsKey, get, put, remove 操作

4. itertator 采用 fast-fail 机制

5. values 继承于 Collection, EntrySet 和 KeySet 则继承于 Set

6. DeletionEntry 删除指定的元素,fixAfterDeletion 对删除后的树节点进行再平衡,使得 TreeMap 保持红黑树的特性。

二、TreeMap方法摘要:

构造方法摘要
TreeMap()
          使用键的自然顺序构造一个新的、空的树映射。
TreeMap(Comparator<? super K> comparator)

          构造一个新的、空的树映射,该映射根据给定比较器进行排序。
TreeMap(Map<? extends K,? extends V> m)

          构造一个与给定映射具有相同映射关系的新的树映射,该映射根据其键的自然顺序 进行排序。
TreeMap(SortedMap<K,? extends V> m)

          构造一个与指定有序映射具有相同映射关系和相同排序顺序的新的树映射。
方法摘要
 Map.Entry<K,V> ceilingEntry(K key)

          返回一个键-值映射关系,它与大于等于给定键的最小键关联;如果不存在这样的键,则返回
null
 K ceilingKey(K key)

          返回大于等于给定键的最小键;如果不存在这样的键,则返回 null
 void clear()

          从此映射中移除所有映射关系。
 Object clone()

          返回此 TreeMap 实例的浅表副本。
 Comparator<? super K> comparator()

          返回对此映射中的键进行排序的比较器;如果此映射使用键的自然顺序,则返回 null
 boolean containsKey(Object key)

          如果此映射包含指定键的映射关系,则返回 true
 boolean containsValue(Object value)

          如果此映射为指定值映射一个或多个键,则返回 true
 NavigableSet<K> descendingKeySet()

          返回此映射中所包含键的逆序 NavigableSet
视图。
 NavigableMap<K,V> descendingMap()

          返回此映射中所包含映射关系的逆序视图。
 Set<Map.Entry<K,V>> entrySet()

          返回此映射中包含的映射关系的 Set 视图。
 Map.Entry<K,V> firstEntry()

          返回一个与此映射中的最小键关联的键-值映射关系;如果映射为空,则返回 null
 K firstKey()

          返回此映射中当前第一个(最低)键。
 Map.Entry<K,V> floorEntry(K key)

          返回一个键-值映射关系,它与小于等于给定键的最大键关联;如果不存在这样的键,则返回
null
 K floorKey(K key)

          返回小于等于给定键的最大键;如果不存在这样的键,则返回 null
 V get(Object key)

          返回指定键所映射的值,如果对于该键而言,此映射不包含任何映射关系,则返回 null
 SortedMap<K,V> headMap(K toKey)

          返回此映射的部分视图,其键值严格小于 toKey
 NavigableMap<K,V> headMap(K toKey,
boolean inclusive)

          返回此映射的部分视图,其键小于(或等于,如果
inclusive 为 true)toKey
 Map.Entry<K,V> higherEntry(K key)

          返回一个键-值映射关系,它与严格大于给定键的最小键关联;如果不存在这样的键,则返回
null
 K higherKey(K key)

          返回严格大于给定键的最小键;如果不存在这样的键,则返回 null
 Set<K> keySet()

          返回此映射包含的键的 Set 视图。
 Map.Entry<K,V> lastEntry()

          返回与此映射中的最大键关联的键-值映射关系;如果映射为空,则返回 null
 K lastKey()

          返回映射中当前最后一个(最高)键。
 Map.Entry<K,V> lowerEntry(K key)

          返回一个键-值映射关系,它与严格小于给定键的最大键关联;如果不存在这样的键,则返回
null
 K lowerKey(K key)

          返回严格小于给定键的最大键;如果不存在这样的键,则返回 null
 NavigableSet<K> navigableKeySet()

          返回此映射中所包含键的 NavigableSet
视图。
 Map.Entry<K,V> pollFirstEntry()

          移除并返回与此映射中的最小键关联的键-值映射关系;如果映射为空,则返回 null
 Map.Entry<K,V> pollLastEntry()

          移除并返回与此映射中的最大键关联的键-值映射关系;如果映射为空,则返回 null
 V put(K key, V value)

          将指定值与此映射中的指定键进行关联。
 void putAll(Map<? extends K,? extends V> map)

          将指定映射中的所有映射关系复制到此映射中。
 V remove(Object key)

          如果此 TreeMap 中存在该键的映射关系,则将其删除。
 int size()

          返回此映射中的键-值映射关系数。
 NavigableMap<K,V> subMap(K fromKey,
boolean fromInclusive, K toKey, boolean toInclusive)


          返回此映射的部分视图,其键的范围从 fromKey
toKey
 SortedMap<K,V> subMap(K fromKey, K toKey)

          返回此映射的部分视图,其键值的范围从 fromKey(包括)到
toKey(不包括)。
 SortedMap<K,V> tailMap(K fromKey)

          返回此映射的部分视图,其键大于等于 fromKey
 NavigableMap<K,V> tailMap(K fromKey,
boolean inclusive)

          返回此映射的部分视图,其键大于(或等于,如果
inclusive 为 true)fromKey
 Collection<V> values()

          返回此映射包含的值的 Collection 视图。

参考文章:https://www.cnblogs.com/TonyYPZhang/p/5747850.html

Java集合框架之TreeMap浅析的更多相关文章

  1. Java集合框架之TreeSet浅析

    Java集合框架之TreeSet浅析 一.TreeSet综述: 1.1TreeSet简介: TreeSet是Java集合框架的重要成员,先来看看TreeSet在jdk1.8中的定义吧: public ...

  2. Java集合框架之HashMap浅析

    Java集合框架之HashMap浅析 一.HashMap综述: 1.1.HashMap概述 位于java.util包下的HashMap是Java集合框架的重要成员,它在jdk1.8中定义如下: pub ...

  3. Java集合框架之HashSet浅析

    Java集合框架之HashSet浅析 一.HashSet综述: 1.1HashSet简介 位于java.util包下的HashSet是Java集合框架的重要成员,它在jdk1.8中定义如下: publ ...

  4. Java集合框架之Vector浅析

    Java集合框架之Vector浅析 一.Vector概述: 位于java.util包下的Vector是Java集合框架的重要一员,虽然没有ArrayList那么的常用,但是我们还要对其做相关学习: 1 ...

  5. Java集合框架之LinkedList浅析

    Java集合框架之LinkedList浅析 一.LinkedList综述: 1.1LinkedList简介 同ArrayList一样,位于java.util包下的LinkedList是Java集合框架 ...

  6. Java集合框架之ArrayList浅析

    Java集合框架之ArrayList浅析 一.ArrayList综述: 位于java.util包下的ArrayList是java集合框架的重要成员,它就是传说中的动态数组,用MSDN中的说法,就是Ar ...

  7. Java集合框架系列大纲

    ###Java集合框架之简述 Java集合框架之Collection Java集合框架之Iterator Java集合框架之HashSet Java集合框架之TreeSet Java集合框架之Link ...

  8. Java集合框架之Map接口浅析

    Java集合框架之Map接口浅析 一.Map接口综述: 1.1java.util.Map<k, v>简介 位于java.util包下的Map接口,是Java集合框架的重要成员,它是和Col ...

  9. 【java集合框架源码剖析系列】java源码剖析之TreeMap

    注:博主java集合框架源码剖析系列的源码全部基于JDK1.8.0版本.本博客将从源码角度带领大家学习关于TreeMap的知识. 一TreeMap的定义: public class TreeMap&l ...

随机推荐

  1. 《VR入门系列教程》之15---配置Oculus的开发环境

    安装Oculus SDK     在使用类似Unity3D之类的引擎开发Oculus Rift应用之前,你必须先安装Oculus的SDK,在Oculus的官网上可以下载:http://develope ...

  2. CentOS 下编译安装Apache

    CentOS 下编译安装Apache 卸载原有的apache 首先从 http://httpd.apache.or 下载apache源码包httpd-2.4.4.tar.gz然后从 http://ap ...

  3. difflib python

    difflib -帮助进行差异化比较 这个模块提供的类和方法用来进行差异化比较,它能够生成文本或者html格式的差异化比较结果,如果需要比较目录的不同,可以使用filecmp模块. 例子: # -*- ...

  4. QRCode生成二维码,jq QRCode生成二维码,QRCode生成电子名片

    [QRCode官网]http://phpqrcode.sourceforge.net/ PHP QRCode生成二维码 官网下载QRCode源码包,引入源码包中的 qrlib.php . <?p ...

  5. S2:log4j

    配置步骤 1.引入jar,放到lib中,jar包被项目管理 2.在src目录下copy了一个文件log4j.properties 3.使用Logger   String word="会员登记 ...

  6. MATLAB使用过程中遇到的问题(持续更新)

    note:如果对你有帮助,请点赞评论哟!!! 问题1:每次双击.m文件都会自动打开一个matlab程序 step1:下载这个文件 http://pan.baidu.com/s/1pL2ULOf ste ...

  7. javascript基础案例解析

    学完了JavaScript基础部分,总结出一些基本案例,以备日后查看! 1.九九乘法口诀表:在控制台中输出九九乘法口诀表!代码如下: <!DOCTYPE html> <html> ...

  8. Linux lsof工具介绍

    引言 在<Linux fuser工具介绍>一文中,与大家一起学习了fuser工具的使用方法."lsof"——list open files,lsof也是Linux下用于 ...

  9. python语言特点简介 以及在Windows以及Mac中安装以及配置的注意事项

    正如前一篇随笔所提到的,python属于解释型语言 python语言有两个特点: 1.胶水语言(历史遗留问题,原来Perl语言作为Unix内置标准件,获得极大追捧,作为竞争者的python一开始是作为 ...

  10. 深入剖析PHP7内核源码(一)- PHP架构与生命周期

    PHP7 为什么这么快? 全新的zval 更节约的空间,栈上分配内存 zend_string 存储字符串的Hash值,数组查询的时候不需要进行Hash计算 在HashTable桶内直接存数据,减少了内 ...