Java ConcurrentHashMap在内部维护分区。每个分区可以分别进行锁定。在某些情况下,多个线程访问的所有键都落在同一个分区中,分区可能没有帮助。进一步增加分区数量会提高并发性。
为什么Java为分区计数提供默认值为16,而不是非常高的值?在Map中,大量分区的性能是什么?
发布于 2013-06-21 11:22:05
为什么Java为分区计数提供默认值为16,而不是非常高的值?
很少有这么多CPU(线程数量并不重要)同时使用相同的CHM。如果您真的需要这样做,通常有一种更好的方法来编写您的应用程序,从而避免这种情况。
例如,假设您有1000个线程,但只有8个CPU。这意味着最多只有8个线程在运行和访问CHM,前提是您的程序没有做任何有用的事情,例如其他任何事情。
在实际程序中,很少有超过10%的时间使用一个集合。这是因为通常涉及到一些IO,或者重新构造线程以使用自己的集合副本并在最后将它们收集在一起是有意义的。
在Map中,大量分区的性能是什么?
您浪费了一些内存,这并不重要,但大多数情况下,您会浪费一些限制在32 KB以内的L1缓存和相对珍贵的资源。
https://stackoverflow.com/questions/17233924
复制相似问题