當前位置: 首頁>>代碼示例>>Java>>正文


Java CyclicBarrier.reset方法代碼示例

本文整理匯總了Java中java.util.concurrent.CyclicBarrier.reset方法的典型用法代碼示例。如果您正苦於以下問題:Java CyclicBarrier.reset方法的具體用法?Java CyclicBarrier.reset怎麽用?Java CyclicBarrier.reset使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在java.util.concurrent.CyclicBarrier的用法示例。


在下文中一共展示了CyclicBarrier.reset方法的10個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: makeBarrier

import java.util.concurrent.CyclicBarrier; //導入方法依賴的package包/類
synchronized void makeBarrier() {
        if (numPlayers < 1) {
            log.warning("cannot make barrier for " + numPlayers + " viewers - something is wrong");
            log.warning("disabling sychronized playback because probably multiple viewers are active but we are not playing set of sychronized files");
            outer.getToggleSyncEnabledAction().actionPerformed(null);
            // toggle all the viewers syncenabled menu item
//               JOptionPane.showMessageDialog(null,"Disabled sychronized playback because files are not part of sychronized set");
            return;
        }
        log.info("making barrier for " + this);
        barrier = new CyclicBarrier(numPlayers, new Runnable() {

            public void run() {
                // this is run after await synchronization; it updates the time to read events from each AEInputStream
//                        log.info(Thread.currentThread()+" resetting barrier");
                barrier.reset();
                setTime(getTime() + getTimesliceUs());
            }
        });
    }
 
開發者ID:SensorsINI,項目名稱:jaer,代碼行數:21,代碼來源:SyncPlayer.java

示例2: testReset_BrokenBarrier

import java.util.concurrent.CyclicBarrier; //導入方法依賴的package包/類
/**
 * A reset of an active barrier causes waiting threads to throw
 * BrokenBarrierException
 */
public void testReset_BrokenBarrier() throws InterruptedException {
    final CyclicBarrier c = new CyclicBarrier(3);
    final CountDownLatch pleaseReset = new CountDownLatch(2);
    Thread t1 = new ThreadShouldThrow(BrokenBarrierException.class) {
        public void realRun() throws Exception {
            pleaseReset.countDown();
            c.await();
        }};
    Thread t2 = new ThreadShouldThrow(BrokenBarrierException.class) {
        public void realRun() throws Exception {
            pleaseReset.countDown();
            c.await();
        }};

    t1.start();
    t2.start();
    await(pleaseReset);

    awaitNumberWaiting(c, 2);
    c.reset();
    awaitTermination(t1);
    awaitTermination(t2);
}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:28,代碼來源:CyclicBarrierTest.java

示例3: testReset_NoBrokenBarrier

import java.util.concurrent.CyclicBarrier; //導入方法依賴的package包/類
/**
 * A reset before threads enter barrier does not throw
 * BrokenBarrierException
 */
public void testReset_NoBrokenBarrier() throws Exception {
    final CyclicBarrier c = new CyclicBarrier(3);
    c.reset();

    Thread t1 = newStartedThread(new CheckedRunnable() {
        public void realRun() throws Exception {
            c.await();
        }});
    Thread t2 = newStartedThread(new CheckedRunnable() {
        public void realRun() throws Exception {
            c.await();
        }});

    c.await();
    awaitTermination(t1);
    awaitTermination(t2);
}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:22,代碼來源:CyclicBarrierTest.java

示例4: testResetAfterCommandException

import java.util.concurrent.CyclicBarrier; //導入方法依賴的package包/類
/**
 * Reset of a barrier after a failed command reinitializes it.
 */
public void testResetAfterCommandException() throws Exception {
    final CyclicBarrier barrier =
        new CyclicBarrier(3, new Runnable() {
                public void run() {
                    throw new NullPointerException(); }});
    for (int i = 0; i < 2; i++) {
        final CyclicBarrier start = new CyclicBarrier(3);
        Thread t1 = new ThreadShouldThrow(BrokenBarrierException.class) {
            public void realRun() throws Exception {
                start.await();
                barrier.await();
            }};

        Thread t2 = new ThreadShouldThrow(BrokenBarrierException.class) {
            public void realRun() throws Exception {
                start.await();
                barrier.await();
            }};

        t1.start();
        t2.start();
        start.await();
        awaitNumberWaiting(barrier, 2);
        try {
            barrier.await();
            shouldThrow();
        } catch (NullPointerException success) {}
        awaitTermination(t1);
        awaitTermination(t2);
        assertTrue(barrier.isBroken());
        assertEquals(0, barrier.getNumberWaiting());
        barrier.reset();
        assertFalse(barrier.isBroken());
        assertEquals(0, barrier.getNumberWaiting());
    }
}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:40,代碼來源:CyclicBarrierTest.java

示例5: testResetWithoutBreakage

import java.util.concurrent.CyclicBarrier; //導入方法依賴的package包/類
/**
 * Reset of a non-broken barrier does not break barrier
 */
public void testResetWithoutBreakage() throws Exception {
    final CyclicBarrier barrier = new CyclicBarrier(3);
    for (int i = 0; i < 3; i++) {
        final CyclicBarrier start = new CyclicBarrier(3);
        Thread t1 = newStartedThread(new CheckedRunnable() {
            public void realRun() throws Exception {
                start.await();
                barrier.await();
            }});

        Thread t2 = newStartedThread(new CheckedRunnable() {
            public void realRun() throws Exception {
                start.await();
                barrier.await();
            }});

        start.await();
        barrier.await();
        awaitTermination(t1);
        awaitTermination(t2);
        assertFalse(barrier.isBroken());
        assertEquals(0, barrier.getNumberWaiting());
        if (i == 1) barrier.reset();
        assertFalse(barrier.isBroken());
        assertEquals(0, barrier.getNumberWaiting());
    }
}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:31,代碼來源:CyclicBarrierTest.java

示例6: testResetAfterInterrupt

import java.util.concurrent.CyclicBarrier; //導入方法依賴的package包/類
/**
 * Reset of a barrier after interruption reinitializes it.
 */
public void testResetAfterInterrupt() throws Exception {
    final CyclicBarrier barrier = new CyclicBarrier(3);
    for (int i = 0; i < 2; i++) {
        final CyclicBarrier start = new CyclicBarrier(3);
        Thread t1 = new ThreadShouldThrow(InterruptedException.class) {
            public void realRun() throws Exception {
                start.await();
                barrier.await();
            }};

        Thread t2 = new ThreadShouldThrow(BrokenBarrierException.class) {
            public void realRun() throws Exception {
                start.await();
                barrier.await();
            }};

        t1.start();
        t2.start();
        start.await();
        t1.interrupt();
        awaitTermination(t1);
        awaitTermination(t2);
        assertTrue(barrier.isBroken());
        assertEquals(0, barrier.getNumberWaiting());
        barrier.reset();
        assertFalse(barrier.isBroken());
        assertEquals(0, barrier.getNumberWaiting());
    }
}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:33,代碼來源:CyclicBarrierTest.java

示例7: forceUnblockAllExecutors

import java.util.concurrent.CyclicBarrier; //導入方法依賴的package包/類
@After
public void forceUnblockAllExecutors() {
    for (CyclicBarrier barrier: blockedExecutors) {
        barrier.reset();
    }
}
 
開發者ID:justor,項目名稱:elasticsearch_my,代碼行數:7,代碼來源:RetryTests.java

示例8: main

import java.util.concurrent.CyclicBarrier; //導入方法依賴的package包/類
public static void main(String[] args) throws Exception {
    final int NUMBER_OF_JAVA_PRIORITIES =
            Thread.MAX_PRIORITY - Thread.MIN_PRIORITY + 1;
    final CyclicBarrier barrier =
            new CyclicBarrier(NUMBER_OF_JAVA_PRIORITIES + 1);

    for (int p = Thread.MIN_PRIORITY; p <= Thread.MAX_PRIORITY; ++p) {
        final int priority = p;
        new Thread("Priority=" + p) {
            {
                setPriority(priority);
            }
            public void run() {
                try {
                    barrier.await(); // 1st
                    barrier.await(); // 2nd
                } catch (Exception exc) {
                    // ignore
                }
            }
        }.start();
    }
    barrier.await(); // 1st

    int matches = 0;
    List<String> failed = new ArrayList<>();
    try {
        String pid = getPid();
        String jstack = System.getProperty("java.home") + "/../bin/jstack";
        Process process = new ProcessBuilder(jstack, pid)
                .redirectErrorStream(true).start();
        Pattern pattern = Pattern.compile(
                "\\\"Priority=(\\d+)\\\".* prio=(\\d+).*");
        try (BufferedReader reader = new BufferedReader(
                new InputStreamReader(process.getInputStream()))) {
            String line;
            while((line = reader.readLine()) != null) {
                Matcher matcher = pattern.matcher(line);
                if (matcher.matches()) {
                    matches += 1;
                    String expected = matcher.group(1);
                    String actual = matcher.group(2);
                    if (!expected.equals(actual)) {
                        failed.add(line);
                    }
                }
            }
        }
        barrier.await(); // 2nd
    } finally {
        barrier.reset();
    }

    if (matches != NUMBER_OF_JAVA_PRIORITIES) {
        throw new AssertionError("matches: expected " +
                NUMBER_OF_JAVA_PRIORITIES + ", but was " + matches);
    }
    if (!failed.isEmpty()) {
        throw new AssertionError(failed.size() + ":" + failed);
    }
    System.out.println("Test passes.");
}
 
開發者ID:arodchen,項目名稱:MaxSim,代碼行數:63,代碼來源:Test7194254.java

示例9: main

import java.util.concurrent.CyclicBarrier; //導入方法依賴的package包/類
public static void main(String[] args) throws Throwable {
    final int NUMBER_OF_JAVA_PRIORITIES =
            Thread.MAX_PRIORITY - Thread.MIN_PRIORITY + 1;
    final CyclicBarrier barrier =
            new CyclicBarrier(NUMBER_OF_JAVA_PRIORITIES + 1);

    for (int p = Thread.MIN_PRIORITY; p <= Thread.MAX_PRIORITY; ++p) {
        final int priority = p;
        new Thread("Priority=" + p) {
            {
                setPriority(priority);
            }
            public void run() {
                try {
                    barrier.await(); // 1st
                    barrier.await(); // 2nd
                } catch (Exception exc) {
                    // ignore
                }
            }
        }.start();
    }
    barrier.await(); // 1st

    int matches = 0;
    ArrayList<String> failed = new ArrayList<>();
    ProcessBuilder pb = new ProcessBuilder(
            JDKToolFinder.getJDKTool("jstack"),
            String.valueOf(ProcessTools.getProcessId()));

    String[] output = new OutputAnalyzer(pb.start()).getOutput().split("\\n+");

    Pattern pattern = Pattern.compile(
            "\\\"Priority=(\\d+)\\\".* prio=(\\d+).*");
    for (String line : output) {
        Matcher matcher = pattern.matcher(line);
        if (matcher.matches()) {
            matches += 1;
            String expected = matcher.group(1);
            String actual = matcher.group(2);
            if (!expected.equals(actual)) {
                failed.add(line);
            }
        }
    }
    barrier.await(); // 2nd
    barrier.reset();

    assertEquals(matches, NUMBER_OF_JAVA_PRIORITIES);
    assertTrue(failed.isEmpty(), failed.size() + ":" + failed);
}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:52,代碼來源:ThreadPriorities.java

示例10: reset

import java.util.concurrent.CyclicBarrier; //導入方法依賴的package包/類
private static void reset(CyclicBarrier barrier) {
    barrier.reset();
    check(! barrier.isBroken());
    equal(barrier.getNumberWaiting(), 0);
}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:6,代碼來源:Basic.java


注:本文中的java.util.concurrent.CyclicBarrier.reset方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。