HashMap 与 ConcurrentHashMap 的异同

        `HashMap` 和 `ConcurrentHashMap` 都是用于存储键值对的集合类,但它们在多线程环境下的行为和特点有所不同:

共同点:

1. 存储键值对: 两者都是用来存储键值对的数据结构,可以对键进行快速查找。

2. 基于哈希表: 内部实现都是基于哈希表,通过哈希码来定位存储位置。

不同点:

1. 线程安全性:

   `HashMap` 不是线程安全的,如果在多线程环境下并发地进行操作(读取和写入),可能会导致不确定的结果。

   `ConcurrentHashMap` 是线程安全的,它使用了锁分段技术(Segment),将哈希表分成多个小的片段,每个片段上都有自己的锁,不同的线程可以同时访问不同的片段,提高了并发性能。

2. 性能:

   在单线程环境下,`HashMap` 的性能可能会更好,因为它不需要额外的同步操作。

   在多线程环境下,`ConcurrentHashMap` 的性能可能更好,因为它允许多个线程同时进行读操作,并发性能更高。

3. 迭代器:

   `HashMap` 的迭代器是 fail-fast 的,即在迭代过程中如果集合被修改,会立即抛出 ConcurrentModificationException 异常。

   `ConcurrentHashMap` 的迭代器是弱一致性的(weakly consistent),它不会抛出 ConcurrentModificationException 异常,但在迭代期间如果集合被修改,迭代器可能会反映出修改前或修改后的状态,不保证在迭代过程中能感知到所有的修改。

        总的来说,`ConcurrentHashMap` 在多线程环境下提供了更好的并发性能和线程安全性,适用于并发读写操作的场景;而 `HashMap` 在单线程环境或者不需要考虑线程安全的情况下可能性能更好。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

郭梓航

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值