1. 首页
  2. Java基础

053-五十三、Java之TreeMap详解

TreeMap 简介

  1. 是一个有序的key-value集合,它是通过红黑树实现的。该映射根据其键的自然顺序进行排序,或者根据创建映射时提供的 Comparator 进行排序,具体取决于使用的构造方法。
    2.是继承了AbstractMap,也是以key-value集合存储。实现了NavigableMap接口,可以支持一系列的导航方法。

比如返回有序的key集合。实现了Cloneable克隆接口。实现了java.io.Serializable序列化接口。另外,TreeMap是非同步的。

构造方法


TreeMap() 使用键的自然顺序构造一个新的、空的树映射。 TreeMap(Comparator<? super K> comparator) 构造一个新的、空的树映射,该映射根据给定比较器进行排序。 TreeMap(Map<? extends K,? extends V> m) 构造一个与给定映射具有相同映射关系的新的树映射,该映射根据其键的自然顺序 进行排序。 TreeMap(SortedMap<K,? extends V> m) 构造一个与指定有序映射具有相同映射关系和相同排序顺序的新的树映射。

常用方法

size()

返回此映射中的键-值映射关系数。


TreeMap<String,String> tree = new TreeMap<>(); tree.put("1","zhangsan1"); tree.put("2","zhangsan2"); tree.put("3","zhangsan3"); tree.put("4","zhangsan4"); /** * 测试size方法,打印应该是4 */ System.out.println(tree.size()); 结果:4

put(K key, V value)

将指定值与此映射中的指定键进行关联。
这个put方法上面已经测试过了就不需要在演示了。

putAll(Map<? extends K,? extends V> map)

将指定映射中的所有映射关系复制到此映射中。


Map<String,String> map = new HashMap<>(); map.put("map1","map1"); map.put("map2","map2"); map.put("map3","map3"); TreeMap<String,String> tree = new TreeMap<>(); tree.put("1","zhangsan1"); tree.put("2","zhangsan2"); tree.put("3","zhangsan3"); tree.put("4","zhangsan4"); /** * 测试putAll方法 */ tree.putAll(map); //将map的3个元素也添加进来了,打印的是7 System.out.println(tree.size()); 结果:7

remove(Object key)

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


TreeMap<String,String> tree = new TreeMap<>(); tree.put("1","zhangsan1"); tree.put("2","zhangsan2"); tree.put("3","zhangsan3"); tree.put("4","zhangsan4"); System.out.println("删除前:"+tree.size()); /** * 测试remove方法 */ tree.remove("1"); System.out.println("删除后:"+tree.size()); 结果: 删除前:4 删除后:3

values()

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


TreeMap<String,String> tree = new TreeMap<>(); tree.put("1","zhangsan1"); tree.put("2","zhangsan2"); tree.put("3","zhangsan3"); tree.put("4","zhangsan4"); /** * values返回值为Collection的集合可以直接使用iterator遍历 */ Collection<String> values = tree.values(); Iterator<String> iterator = values.iterator(); while (iterator.hasNext()) { System.out.print(iterator.next() + "\t"); } 结果:zhangsan1 zhangsan2 zhangsan3 zhangsan4

ceilingEntry(K key)

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


TreeMap<String,String> tree = new TreeMap<>(); tree.put("1","zhangsan1"); tree.put("2","zhangsan2"); tree.put("3","zhangsan3"); tree.put("4","zhangsan4"); /** * ceilingEntry的返回值为:Map.Entry<String, String> * 这个类中有getKey(),getValue */ Map.Entry<String, String> stringStringEntry = tree.ceilingEntry("1"); //获取元素的key System.out.println("getKey:"+ stringStringEntry.getKey()); //获取元素的value值 System.out.println("getValue:"+ stringStringEntry.getValue()); 结果: getKey:1 getValue:zhangsan1

containsKey(Object key)

如果此映射包含指定键的映射关系,则返回 true


TreeMap<String,String> tree = new TreeMap<>(); tree.put("1","zhangsan1"); tree.put("2","zhangsan2"); tree.put("3","zhangsan3"); tree.put("4","zhangsan4"); System.out.println("key为2的在集合中是否存在:"+tree.containsKey("2")); 结果:key为2的在集合中是否存在:true

containsValue(Object value)

如果此映射为指定值映射一个或多个键,则返回 true


TreeMap<String,String> tree = new TreeMap<>(); tree.put("1","zhangsan1"); tree.put("2","zhangsan2"); tree.put("3","zhangsan3"); tree.put("4","zhangsan4"); System.out.println("value为zhangsan3的在集合中是否存在:"+tree.containsValue("zhangsan3")); 结果:value为zhangsan3的在集合中是否存在:true

entrySet()

返回此映射中包含的映射关系的 Set 视图。


TreeMap<String,String> tree = new TreeMap<>(); tree.put("1","zhangsan1"); tree.put("2","zhangsan2"); tree.put("3","zhangsan3"); tree.put("4","zhangsan4"); /** * entrySet方法返回值也是set,也可以使用 */ Set<Map.Entry<String, String>> set = tree.entrySet(); /** * 使用iterator遍历 */ Iterator<Map.Entry<String, String>> iterator = set.iterator(); while (iterator.hasNext()) { System.out.print(iterator.next() + "\t"); } 结果:1=zhangsan1 2=zhangsan2 3=zhangsan3 4=zhangsan4

firstEntry()

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


TreeMap<String,String> tree = new TreeMap<>(); tree.put("1","zhangsan1"); tree.put("2","zhangsan2"); tree.put("3","zhangsan3"); tree.put("4","zhangsan4"); /** * firstEntry方法返回值Map.Entry */ Map.Entry<String, String> entry = tree.firstEntry(); //获取键 System.out.println(entry.getKey()); //获取值 System.out.println(entry.getValue()); 结果: zhangsan1

get(Object key)

返回指定键所映射的值,如果对于该键而言,此映射不包含任何映射关系,则返回 null


TreeMap<String,String> tree = new TreeMap<>(); tree.put("1","zhangsan1"); tree.put("2","zhangsan2"); tree.put("3","zhangsan3"); tree.put("4","zhangsan4"); //根据键来获取值 System.out.println(tree.get("1")); 结果:zhangsan1

keySet()

返回此映射包含的键的 Set 视图。


TreeMap<String,String> tree = new TreeMap<>(); tree.put("1","zhangsan1"); tree.put("2","zhangsan2"); tree.put("3","zhangsan3"); tree.put("4","zhangsan4"); /** * 返回也是set集合,输出都是key */ Set<String> set = tree.keySet(); /** * 使用iterator遍历 * */ Iterator<String> iterator = set.iterator(); while (iterator.hasNext()) { System.out.print(iterator.next() + "\t"); } 结果:1 2 3 4

lastEntry()

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


TreeMap<String,String> tree = new TreeMap<>(); tree.put("1","zhangsan1"); tree.put("2","zhangsan2"); tree.put("3","zhangsan3"); tree.put("4","zhangsan4"); /** * 返回Map.Entry类型,输出的一个元素 */ Map.Entry<String, String> entry = tree.lastEntry(); System.out.print("key:" + entry.getKey()); System.out.println("value:" + entry.getValue()); 结果:key:4 value:zhangsan4

TreeMap排序习题!

以上都是使用的字符串,而 String 类已经即实现了比较的方法
public int compareTo(String anotherString)
,所以不会出问题,大家可以试试使用自定义一个Cat类
属性:int id, String name,然后添加到 treemap 中去,看看会出现什么问题?

写完了如果写得有什么问题,希望读者能够给小编留言,也可以点击[此处扫下面二维码关注微信公众号](https://www.ycbbs.vip/?p=28 "此处扫下面二维码关注微信公众号")

看完两件小事

如果你觉得这篇文章对你挺有启发,我想请你帮我两个小忙:

  1. 关注我们的 GitHub 博客,让我们成为长期关系
  2. 把这篇文章分享给你的朋友 / 交流群,让更多的人看到,一起进步,一起成长!
  3. 关注公众号 「方志朋」,公众号后台回复「666」 免费领取我精心整理的进阶资源教程
  4. JS中文网,Javascriptc中文网是中国领先的新一代开发者社区和专业的技术媒体,一个帮助开发者成长的社区,是给开发者用的 Hacker News,技术文章由为你筛选出最优质的干货,其中包括:Android、iOS、前端、后端等方面的内容。目前已经覆盖和服务了超过 300 万开发者,你每天都可以在这里找到技术世界的头条内容。

    本文著作权归作者所有,如若转载,请注明出处

    转载请注明:文章转载自「 Java极客技术学习 」https://www.javajike.com

    标题:053-五十三、Java之TreeMap详解

    链接:https://www.javajike.com/article/1360.html

« 054-五十四、Java之手写HashMap(上)
052-五十二、Java之HashSet详解»

相关推荐

QR code