author | dl |
Wed, 28 Nov 2018 15:25:14 -0800 | |
changeset 52730 | 345266000aba |
parent 47216 | 71c04702a3d5 |
permissions | -rw-r--r-- |
15283
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
1 |
/* |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
2 |
* Copyright (c) 2013, Oracle and/or its affiliates. All rights reserved. |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
3 |
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
4 |
* |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
5 |
* This code is free software; you can redistribute it and/or modify it |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
6 |
* under the terms of the GNU General Public License version 2 only, as |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
7 |
* published by the Free Software Foundation. |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
8 |
* |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
9 |
* This code is distributed in the hope that it will be useful, but WITHOUT |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
10 |
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
11 |
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
12 |
* version 2 for more details (a copy is included in the LICENSE file that |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
13 |
* accompanied this code). |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
14 |
* |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
15 |
* You should have received a copy of the GNU General Public License version |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
16 |
* 2 along with this work; if not, write to the Free Software Foundation, |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
17 |
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
18 |
* |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
19 |
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
20 |
* or visit www.oracle.com if you need additional information or have any |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
21 |
* questions. |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
22 |
*/ |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
23 |
|
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
24 |
/* |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
25 |
* Written by Doug Lea with assistance from members of JCP JSR-166 |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
26 |
* Expert Group and released to the public domain, as explained at |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
27 |
* http://creativecommons.org/publicdomain/zero/1.0/ |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
28 |
*/ |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
29 |
|
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
30 |
/* Adapted from Dougs CVS test/jsr166e/LongAdderDemo.java |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
31 |
* |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
32 |
* The demo is a micro-benchmark to compare AtomicLong and LongAdder (run |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
33 |
* without any args), this restricted version simply exercises the basic |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
34 |
* functionality of LongAdder, suitable for automated testing (-shortrun). |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
35 |
*/ |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
36 |
|
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
37 |
/* |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
38 |
* @test |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
39 |
* @bug 8005311 |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
40 |
* @run main LongAdderDemo -shortrun |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
41 |
* @summary Basic test for LongAdder |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
42 |
*/ |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
43 |
|
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
44 |
import java.util.concurrent.ExecutorService; |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
45 |
import java.util.concurrent.Executors; |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
46 |
import java.util.concurrent.Phaser; |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
47 |
import java.util.concurrent.atomic.AtomicLong; |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
48 |
import java.util.concurrent.atomic.LongAdder; |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
49 |
|
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
50 |
public class LongAdderDemo { |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
51 |
static final int INCS_PER_THREAD = 10000000; |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
52 |
static final int NCPU = Runtime.getRuntime().availableProcessors(); |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
53 |
static final int SHORT_RUN_MAX_THREADS = NCPU > 1 ? NCPU / 2 : 1; |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
54 |
static final int LONG_RUN_MAX_THREADS = NCPU * 2; |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
55 |
static final ExecutorService pool = Executors.newCachedThreadPool(); |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
56 |
|
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
57 |
public static void main(String[] args) { |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
58 |
boolean shortRun = args.length > 0 && args[0].equals("-shortrun"); |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
59 |
int maxNumThreads = shortRun ? SHORT_RUN_MAX_THREADS : LONG_RUN_MAX_THREADS; |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
60 |
|
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
61 |
System.out.println("Warmup..."); |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
62 |
int half = NCPU > 1 ? NCPU / 2 : 1; |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
63 |
if (!shortRun) |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
64 |
casTest(half, 1000); |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
65 |
adderTest(half, 1000); |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
66 |
|
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
67 |
for (int reps = 0; reps < 2; ++reps) { |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
68 |
System.out.println("Running..."); |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
69 |
for (int i = 1; i <= maxNumThreads; i <<= 1) { |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
70 |
if (!shortRun) |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
71 |
casTest(i, INCS_PER_THREAD); |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
72 |
adderTest(i, INCS_PER_THREAD); |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
73 |
} |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
74 |
} |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
75 |
pool.shutdown(); |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
76 |
} |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
77 |
|
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
78 |
static void casTest(int nthreads, int incs) { |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
79 |
System.out.print("AtomicLong "); |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
80 |
Phaser phaser = new Phaser(nthreads + 1); |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
81 |
AtomicLong a = new AtomicLong(); |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
82 |
for (int i = 0; i < nthreads; ++i) |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
83 |
pool.execute(new CasTask(a, phaser, incs)); |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
84 |
report(nthreads, incs, timeTasks(phaser), a.get()); |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
85 |
} |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
86 |
|
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
87 |
static void adderTest(int nthreads, int incs) { |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
88 |
System.out.print("LongAdder "); |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
89 |
Phaser phaser = new Phaser(nthreads + 1); |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
90 |
LongAdder a = new LongAdder(); |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
91 |
for (int i = 0; i < nthreads; ++i) |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
92 |
pool.execute(new AdderTask(a, phaser, incs)); |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
93 |
report(nthreads, incs, timeTasks(phaser), a.sum()); |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
94 |
} |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
95 |
|
52730
345266000aba
8211283: Miscellaneous changes imported from jsr166 CVS 2018-11
dl
parents:
47216
diff
changeset
|
96 |
static void report(int nthreads, int incs, long elapsedNanos, long sum) { |
15283
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
97 |
long total = (long)nthreads * incs; |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
98 |
if (sum != total) |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
99 |
throw new Error(sum + " != " + total); |
52730
345266000aba
8211283: Miscellaneous changes imported from jsr166 CVS 2018-11
dl
parents:
47216
diff
changeset
|
100 |
double elapsedSecs = (double)elapsedNanos / (1000L * 1000 * 1000); |
345266000aba
8211283: Miscellaneous changes imported from jsr166 CVS 2018-11
dl
parents:
47216
diff
changeset
|
101 |
long rate = total * 1000L / elapsedNanos; |
15283
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
102 |
System.out.printf("threads:%3d Time: %7.3fsec Incs per microsec: %4d\n", |
52730
345266000aba
8211283: Miscellaneous changes imported from jsr166 CVS 2018-11
dl
parents:
47216
diff
changeset
|
103 |
nthreads, elapsedSecs, rate); |
15283
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
104 |
} |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
105 |
|
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
106 |
static long timeTasks(Phaser phaser) { |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
107 |
phaser.arriveAndAwaitAdvance(); |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
108 |
long start = System.nanoTime(); |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
109 |
phaser.arriveAndAwaitAdvance(); |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
110 |
phaser.arriveAndAwaitAdvance(); |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
111 |
return System.nanoTime() - start; |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
112 |
} |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
113 |
|
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
114 |
static final class AdderTask implements Runnable { |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
115 |
final LongAdder adder; |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
116 |
final Phaser phaser; |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
117 |
final int incs; |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
118 |
volatile long result; |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
119 |
AdderTask(LongAdder adder, Phaser phaser, int incs) { |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
120 |
this.adder = adder; |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
121 |
this.phaser = phaser; |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
122 |
this.incs = incs; |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
123 |
} |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
124 |
|
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
125 |
public void run() { |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
126 |
phaser.arriveAndAwaitAdvance(); |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
127 |
phaser.arriveAndAwaitAdvance(); |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
128 |
LongAdder a = adder; |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
129 |
for (int i = 0; i < incs; ++i) |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
130 |
a.increment(); |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
131 |
result = a.sum(); |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
132 |
phaser.arrive(); |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
133 |
} |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
134 |
} |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
135 |
|
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
136 |
static final class CasTask implements Runnable { |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
137 |
final AtomicLong adder; |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
138 |
final Phaser phaser; |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
139 |
final int incs; |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
140 |
volatile long result; |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
141 |
CasTask(AtomicLong adder, Phaser phaser, int incs) { |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
142 |
this.adder = adder; |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
143 |
this.phaser = phaser; |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
144 |
this.incs = incs; |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
145 |
} |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
146 |
|
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
147 |
public void run() { |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
148 |
phaser.arriveAndAwaitAdvance(); |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
149 |
phaser.arriveAndAwaitAdvance(); |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
150 |
AtomicLong a = adder; |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
151 |
for (int i = 0; i < incs; ++i) |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
152 |
a.getAndIncrement(); |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
153 |
result = a.get(); |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
154 |
phaser.arrive(); |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
155 |
} |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
156 |
} |
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
157 |
|
e331a847ff27
8005311: Add Scalable Updatable Variables, DoubleAccumulator, DoubleAdder, LongAccumulator, LongAdder
dl
parents:
diff
changeset
|
158 |
} |