jdk/test/java/util/concurrent/forkjoin/ThreadLessCommon.java
author chegar
Sat, 02 Mar 2013 08:54:37 +0000
changeset 16049 92a3a919d4dc
permissions -rw-r--r--
8008378: FJP.commonPool support parallelism 0, add awaitQuiescence Reviewed-by: chegar Contributed-by: Doug Lea <dl@cs.oswego.edu>, Chris Hegarty <chris.hegarty@oracle.com>
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
16049
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
     1
/*
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
     2
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
     3
 *
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
     4
 * This code is free software; you can redistribute it and/or modify it
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
     5
 * under the terms of the GNU General Public License version 2 only, as
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
     6
 * published by the Free Software Foundation.
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
     7
 *
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
     8
 * This code is distributed in the hope that it will be useful, but WITHOUT
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
     9
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
    10
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
    11
 * version 2 for more details (a copy is included in the LICENSE file that
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
    12
 * accompanied this code).
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
    13
 *
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
    14
 * You should have received a copy of the GNU General Public License version
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
    15
 * 2 along with this work; if not, write to the Free Software Foundation,
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
    16
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
    17
 *
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
    18
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
    19
 * or visit www.oracle.com if you need additional information or have any
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
    20
 * questions.
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
    21
 */
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
    22
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
    23
/*
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
    24
 * This file is available under and governed by the GNU General Public
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
    25
 * License version 2 only, as published by the Free Software Foundation.
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
    26
 * However, the following notice accompanied the original version of this
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
    27
 * file:
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
    28
 *
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
    29
 * Written by Doug Lea with assistance from members of JCP JSR-166
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
    30
 * Expert Group and released to the public domain, as explained at
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
    31
 * http://creativecommons.org/publicdomain/zero/1.0/
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
    32
 */
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
    33
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
    34
/*
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
    35
 * @test
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
    36
 * @bug 8008378
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
    37
 * @summary Basic checks for parallelism 0, and null returning factory
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
    38
 * @run main/othervm -Djava.util.concurrent.ForkJoinPool.common.parallelism=0 ThreadLessCommon
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
    39
 * @run main/othervm -Djava.util.concurrent.ForkJoinPool.common.threadFactory=ThreadLessCommon$NullForkJoinWorkerThreadFactory ThreadLessCommon
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
    40
 * @author Chris Hegarty
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
    41
 */
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
    42
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
    43
import java.util.concurrent.ForkJoinPool;
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
    44
import java.util.concurrent.ForkJoinPool.ForkJoinWorkerThreadFactory;
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
    45
import java.util.concurrent.ForkJoinWorkerThread;
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
    46
import java.util.concurrent.RecursiveTask;
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
    47
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
    48
public class ThreadLessCommon {
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
    49
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
    50
    static final int THRESHOLD = 1000;
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
    51
    static final boolean debug = true;
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
    52
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
    53
    private static void realMain(String[] args) throws Throwable {
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
    54
        if (debug) {
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
    55
            String pp = System.getProperty(
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
    56
                    "java.util.concurrent.ForkJoinPool.common.parallelism");
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
    57
            System.out.println(
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
    58
                    "java.util.concurrent.ForkJoinPool.common.parallelism:" + pp);
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
    59
            String tf = System.getProperty(
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
    60
                    "java.util.concurrent.ForkJoinPool.common.threadFactory");
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
    61
            System.out.println(
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
    62
                    "java.util.concurrent.ForkJoinPool.common.threadFactory:" + tf);
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
    63
        }
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
    64
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
    65
        long from = 0, to = 50000;
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
    66
        RecursiveTask<Long> task = new SumTask(from, to, Thread.currentThread());
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
    67
        long sum = task.invoke();
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
    68
        System.out.printf("%nSum: from [%d] to [%d] = [%d]%n", from, to, sum);
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
    69
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
    70
        task.fork();
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
    71
        sum = task.join();
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
    72
        System.out.printf("%nSum: from [%d] to [%d] = [%d]%n", from, to, sum);
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
    73
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
    74
        sum = ForkJoinPool.commonPool().invoke(task.fork());
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
    75
        System.out.printf("%nSum: from [%d] to [%d] = [%d]%n", from, to, sum);
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
    76
    }
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
    77
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
    78
    static class SumTask extends RecursiveTask<Long> {
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
    79
        final Thread expectedThread;
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
    80
        final long from;
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
    81
        final long to;
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
    82
        SumTask(long from, long to, Thread thread) {
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
    83
            this.from = from; this.to = to; expectedThread = thread;
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
    84
        }
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
    85
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
    86
        @Override
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
    87
        public Long compute() {
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
    88
            check(Thread.currentThread() == expectedThread,
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
    89
                  "Expected " + expectedThread + ", got " + Thread.currentThread());
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
    90
            long range = to - from;
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
    91
            if (range < THRESHOLD) {
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
    92
                long acc = 0;
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
    93
                for (long i = from; i <= to; i++)
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
    94
                    acc = acc + i;
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
    95
                return acc;
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
    96
            } else {
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
    97
                long half = from + range / 2;
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
    98
                SumTask t1 = new SumTask(from, half ,expectedThread);
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
    99
                SumTask t2 = new SumTask(half+1, to ,expectedThread);
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
   100
                if (half % 2 == 0) {
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
   101
                    t1.fork();
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
   102
                    return t2.compute() + t1.join();
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
   103
                } else {
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
   104
                    invokeAll(t1, t2);
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
   105
                    try { return t1.get() + t2.get(); }
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
   106
                    catch (Exception x) { unexpected(x); return 0L;}
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
   107
                }
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
   108
            }
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
   109
        }
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
   110
    }
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
   111
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
   112
    public static class NullForkJoinWorkerThreadFactory
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
   113
        implements ForkJoinWorkerThreadFactory
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
   114
    {
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
   115
        @Override
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
   116
        public ForkJoinWorkerThread newThread(ForkJoinPool pool) {
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
   117
            return null;
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
   118
        }
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
   119
    }
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
   120
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
   121
    //--------------------- Infrastructure ---------------------------
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
   122
    static volatile int passed = 0, failed = 0;
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
   123
    static void pass() {passed++;}
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
   124
    static void fail() {failed++; /*Thread.dumpStack();*/}
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
   125
    static void fail(String msg) {System.out.println(msg); fail();}
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
   126
    static void unexpected(Throwable t) {failed++; t.printStackTrace();}
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
   127
    static void check(boolean cond, String msg) {if (cond) pass(); else fail(msg);}
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
   128
    static void equal(Object x, Object y) {
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
   129
        if (x == null ? y == null : x.equals(y)) pass();
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
   130
        else fail(x + " not equal to " + y);}
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
   131
    public static void main(String[] args) throws Throwable {
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
   132
        try {realMain(args);} catch (Throwable t) {unexpected(t);}
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
   133
        System.out.printf("%nPassed = %d, failed = %d%n%n", passed, failed);
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
   134
        if (failed > 0) throw new AssertionError("Some tests failed");}
92a3a919d4dc 8008378: FJP.commonPool support parallelism 0, add awaitQuiescence
chegar
parents:
diff changeset
   135
}