Duo Zhang created HBASE-16278:
---------------------------------
Summary: Use ConcurrentHashMap instead of ConcurrentSkipListMap if
possible
Key: HBASE-16278
URL: https://issues.apache.org/jira/browse/HBASE-16278
Project: HBase
Issue Type: Bug
Reporter: Duo Zhang
SSD and 10G network make our system CPU bound again, so the speed of memory
operation only code becomes more and more important.
In HBase, if want to use byte[] as a map key, then we will always use CSLM even
if we do not need the map to be ordered. I know that this could save one object
allocation since we can not use byte[] directly as CHM's key. But we all know
that CHM is faster than CSLM, so I wonder if it worth to use CSLM instead of
CHM only because one extra object allocation.
Then I wrote a simple jmh micro benchmark to test the performance of CHM and
CSLM. The code could be found here
https://github.com/Apache9/microbench
It turns out that CHM is still much faster than CSLM with one extra object
allocation.
So I think we should always use CHM if we do not need the keys to be sorted.
--
This message was sent by Atlassian JIRA
(v6.3.4#6332)