其他分享
首页 > 其他分享> > 读少写多的条件下 ConcurrentHashMap 和 ReadWriteLock 的选择

读少写多的条件下 ConcurrentHashMap 和 ReadWriteLock 的选择

作者:互联网

场景是这样的:两个对象往一个 Map 里循环写入,另外一个对象偶尔读一次,写的频率比读的频率高很多。
希望实现的是读的时候暂停写入。
CocurrentHashMap 和 ReadWriteLock 各有什么优劣吗?

先说答案?

应该用ConcurrentHashMap

ReadWriteLock适用于读线程远远多于写线程的情况下,而且一般是有写的情况下读会阻塞——这样下来甚至还不如一般的锁。

 

 

 

 

从简化编程模型来看,应该用 ConcurrentHashMap,用它直接生成 Map 的实例即可。而使用锁机制,你需要自己管理这些锁的状态。

从性能来看,同样应该用 ConcurrentHashMap,因为它内部已经对读写操作进行了分块优化,在大多数情况下,读写可以同时进行。你自己很难实现得更加高效。

标签:Map,读少,ReadWriteLock,写入,ConcurrentHashMap,线程,频率
来源: https://www.cnblogs.com/xwj7aom1/p/14492680.html