容器-并发(1)

HashMap ConcurrentHashMap HashTable synchronizedMap

1.HashMap与HashTable:
HashMap 非线程安全,支持null key 和null 值。 而HashTable线程安全,不支持null key和null 值。 HashMap 可以很容易转换到LinkedHashMap(支持插入有序,设置,访问,删除有序,而TreeMap支持对Key有序,TreeMap实则为红黑树), 而HashTable不能。

2.ConcurrentHashMap:
在并发环境下,ConcurrentHashMap弱化了size(), isEmpty()函数的语义,加强了get, put, containsKey, remove等操作的性能。即size, isEmpty返回的值可能已经过期,它实际上只是一个估计值,并不是一个精确值。虽然看上去这很不靠谱,但在并发环境下,这两个方法的用处很小,因为他们的返回值总在不断变化。
使用ConcurrentHashMap的话,不要通过synchronize该对象来创建新的原子操作。因为ConcurrentHashMap的加锁粒度要小很多,并非是锁整个对象,你把整个对象锁住了,辛辛苦苦写细粒度锁的author会打死你的,想通过简单的锁整个对象来创建新的原子操作,可以了解一下Collections.synchronizedMap()。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值