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

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

阅读 8.4k
2 个回答

应该用ConcurrentHashMap

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

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

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

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题