RFR (XS): CR 8006176: Switch to optimal identity hash code generator
Aleksey Shipilev
aleksey.shipilev at oracle.com
Mon Jan 14 03:55:18 PST 2013
Hi,
This is a simple issue reported by one of our customers, relying heavily
on System.identityHashCode(...) in their code. They figured out the
global state in current identity hashcode generator penalizes
scalability. Their workaround is to switch -XX:hashCode=5 to the
thread-local Marsaglia's XorShift generator.
The motivation is really simple when the targeted microbenchmark is
considered: asking System.identityHashCode(new Object()) continuously in
multiple threads.
On 2x2 Intel i5-2520M, Linux x86_64, JDK 7u12-ea:
1 thread:
-XX:hashCode=0: 11.3 +- 0.9 ops/usec
-XX:hashCode=1: 12.3 +- 0.3 ops/usec
-XX:hashCode=2: 12.8 +- 0.2 ops/usec
-XX:hashCode=3: 11.7 +- 0.1 ops/usec
-XX:hashCode=4: 12.5 +- 0.1 ops/usec
-XX:hashCode=5: 12.1 +- 0.2 ops/usec
4 threads:
-XX:hashCode=0: 19.3 +- 0.1 ops/usec
-XX:hashCode=1: 25.5 +- 0.3 ops/usec
-XX:hashCode=2: 26.8 +- 0.1 ops/usec
-XX:hashCode=3: 20.8 +- 0.1 ops/usec
-XX:hashCode=4: 25.1 +- 0.5 ops/usec
-XX:hashCode=5: 24.9 +- 0.2 ops/usec
So, even on this small machine, the scalability improvement is very
telling 19.3 -> 24.9 ops/usec.
On 2x8x2 SandyBridge box, JDK8 HEAD:
1 thread:
-XX:hashCode=0: 16.9 +- 0.5 ops/usec
-XX:hashCode=1: 19.2 +- 0.1 ops/usec
-XX:hashCode=2: 18.9 +- 0.3 ops/usec
-XX:hashCode=3: 18.9 +- 0.4 ops/usec
-XX:hashCode=4: 19.0 +- 0.1 ops/usec
-XX:hashCode=5: 18.5 +- 0.3 ops/usec
32 threads:
-XX:hashCode=0: 10.7 +- 0.1 ops/usec
-XX:hashCode=1: 175.2 +- 4.9 ops/usec
-XX:hashCode=2: 184.8 +- 3.7 ops/usec
-XX:hashCode=3: 14.2 +- 0.1 ops/usec
-XX:hashCode=4: 160.0 +- 2.6 ops/usec
-XX:hashCode=5: 176.6 +- 6.0 ops/usec
Note whooping scalability increase when dealing with non-shared generators.
Randomicity is another concern, and our internal tests show that
thread-local PRNG (mode 5) is as good as the global PRNG (mode 0), you
can see that here:
http://cr.openjdk.java.net/~shade/8006176/randomicity/
It turns out that modes 0, 2, and 5 are random enough; and mode 5 is the
most scalable one. Hence, we'd like to switch to mode 5, here's the webrev:
http://cr.openjdk.java.net/~shade/8006176/webrev.00/
Thanks,
-Aleksey.
More information about the hotspot-runtime-dev
mailing list