57 |
|
*/ |
58 |
|
public void update(double x) { |
59 |
|
long lx = Double.doubleToRawLongBits(x); |
60 |
< |
Cell[] as; long b, v; HashCode hc; Cell a; int n; |
60 |
> |
Cell[] as; long b, v; int[] hc; Cell a; int n; |
61 |
|
if ((as = cells) != null || |
62 |
|
(Double.longBitsToDouble(b = base) < x && !casBase(b, lx))) { |
63 |
|
boolean uncontended = true; |
64 |
< |
int h = (hc = threadHashCode.get()).code; |
65 |
< |
if (as == null || (n = as.length) < 1 || |
66 |
< |
(a = as[(n - 1) & h]) == null || |
64 |
> |
if ((hc = threadHashCode.get()) == null || |
65 |
> |
as == null || (n = as.length) < 1 || |
66 |
> |
(a = as[(n - 1) & hc[0]]) == null || |
67 |
|
(Double.longBitsToDouble(v = a.value) < x && |
68 |
|
!(uncontended = a.cas(v, lx)))) |
69 |
|
retryUpdate(lx, hc, uncontended); |
72 |
|
|
73 |
|
/** |
74 |
|
* Returns the current maximum. The returned value is |
75 |
< |
* <em>NOT</em> an atomic snapshot: invocation in the absence of |
75 |
> |
* <em>NOT</em> an atomic snapshot; invocation in the absence of |
76 |
|
* concurrent updates returns an accurate result, but concurrent |
77 |
|
* updates that occur while the value is being calculated might |
78 |
|
* not be incorporated. |