検索

ホームページ  >  に質問  >  本文

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

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

PHPzPHPz2767日前1165

全員に返信(2)返信します

  • 阿神

    阿神2017-04-17 11:47:10

    应该用ConcurrentHashMap

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

    返事
    0
  • 高洛峰

    高洛峰2017-04-17 11:47:10

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

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

    返事
    0
  • キャンセル返事