知识点复习04 java集合

TreeMap和LinkedHashMap是有序的(TreeMap默认升序,LinkedHashMap则记录了插入顺序)

Java中的TreeMap用于存储与HashMap类非常相似的键值对。区别在于TreeMap提供了一种以排序顺序存储键/值对的有效方法。它是基于红黑树NavigableMap实现。

在这个Java TreeMap教程中,我们将学习TreeMap类,它的方法,用例和其他重要细节。

2. TreeMap功能

关于Java TreeMap类的重点是:

  • 它存储类似于HashMap的键值对。
  • 它只允许不同的键。无法复制密钥。
  • 它不能有null密钥但可以有多个null值。
  • 它按排序顺序(自然顺序)或按Comparator地图创建时提供的密钥存储密钥。
  • 它提供了有保证的log(n)的时间成本,为containsKeygetputremove操作。
  • 它不同步。用于Collections.synchronizedSortedMap(new TreeMap())在并发环境中工作。
  • iterator方法返回的迭代器是快速失败的
  • 7. TreeMap性能
  • TreeMap 为大多数操作提供log(n)的性能,如add(),remove()和contains()。对于相同的操作,HashMap以恒定时间性能O(1)执行。这样,HashMap比TreeMap表现更好。

    TreeMap在内存管理方面具有更好的性能,因为它不在内部维护一个数组来存储键值对。在HashMap中,数组大小是在初始化或调整大小时确定的,如果当时通常需要的话。它浪费了记忆。TreeMap没有这样的问题。

我们可以使用Collections.synchronizedSortedMap(new TreeMap())显式获取树图的同步视图。

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值