读少写多的条件下 ConcurrentHashMap 和 ReadWriteLock 的选择
作者:互联网
场景是这样的:两个对象往一个 Map
里循环写入,另外一个对象偶尔读一次,写的频率比读的频率高很多。
希望实现的是读的时候暂停写入。CocurrentHashMap
和 ReadWriteLock
各有什么优劣吗?
先说答案?
应该用ConcurrentHashMap
。
ReadWriteLock
适用于读线程远远多于写线程的情况下,而且一般是有写的情况下读会阻塞——这样下来甚至还不如一般的锁。
从简化编程模型来看,应该用 ConcurrentHashMap
,用它直接生成 Map
的实例即可。而使用锁机制,你需要自己管理这些锁的状态。
从性能来看,同样应该用 ConcurrentHashMap
,因为它内部已经对读写操作进行了分块优化,在大多数情况下,读写可以同时进行。你自己很难实现得更加高效。
标签:Map,读少,ReadWriteLock,写入,ConcurrentHashMap,线程,频率 来源: https://www.cnblogs.com/xwj7aom1/p/14492680.html