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


Java CountDownLatch.countDown方法代碼示例

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


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

示例1: testPullMessage_SuccessWithOrderlyService

import java.util.concurrent.CountDownLatch; //導入方法依賴的package包/類
@Test
public void testPullMessage_SuccessWithOrderlyService() throws Exception {
    final CountDownLatch countDownLatch = new CountDownLatch(1);
    final MessageExt[] messageExts = new MessageExt[1];

    MessageListenerOrderly listenerOrderly = new MessageListenerOrderly() {
        @Override
        public ConsumeOrderlyStatus consumeMessage(List<MessageExt> msgs, ConsumeOrderlyContext context) {
            messageExts[0] = msgs.get(0);
            countDownLatch.countDown();
            return null;
        }
    };
    pushConsumer.registerMessageListener(listenerOrderly);
    pushConsumer.getDefaultMQPushConsumerImpl().setConsumeMessageService(new ConsumeMessageOrderlyService(pushConsumer.getDefaultMQPushConsumerImpl(), listenerOrderly));
    pushConsumer.getDefaultMQPushConsumerImpl().setConsumeOrderly(true);
    pushConsumer.getDefaultMQPushConsumerImpl().doRebalance();
    PullMessageService pullMessageService = mQClientFactory.getPullMessageService();
    pullMessageService.executePullRequestLater(createPullRequest(), 100);

    countDownLatch.await(10, TimeUnit.SECONDS);
    assertThat(messageExts[0].getTopic()).isEqualTo(topic);
    assertThat(messageExts[0].getBody()).isEqualTo(new byte[] {'a'});
}
 
開發者ID:lyy4j,項目名稱:rmq4note,代碼行數:25,代碼來源:DefaultMQPushConsumerTest.java

示例2: testSignalAll

import java.util.concurrent.CountDownLatch; //導入方法依賴的package包/類
public void testSignalAll(boolean fair, final AwaitMethod awaitMethod) {
    final PublicReentrantLock lock = new PublicReentrantLock(fair);
    final Condition c = lock.newCondition();
    final CountDownLatch pleaseSignal = new CountDownLatch(2);
    class Awaiter extends CheckedRunnable {
        public void realRun() throws InterruptedException {
            lock.lock();
            pleaseSignal.countDown();
            await(c, awaitMethod);
            lock.unlock();
        }
    }

    Thread t1 = newStartedThread(new Awaiter());
    Thread t2 = newStartedThread(new Awaiter());

    await(pleaseSignal);
    lock.lock();
    assertHasWaiters(lock, c, t1, t2);
    c.signalAll();
    assertHasNoWaiters(lock, c);
    lock.unlock();
    awaitTermination(t1);
    awaitTermination(t2);
}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:26,代碼來源:ReentrantLockTest.java

示例3: removeAllChangeListenersThrowExceptionOnNonLooperThread

import java.util.concurrent.CountDownLatch; //導入方法依賴的package包/類
@Test
public void removeAllChangeListenersThrowExceptionOnNonLooperThread() {
    final CountDownLatch signalTestFinished = new CountDownLatch(1);
    Thread thread = new Thread(new Runnable() {
        @Override
        public void run() {
            Realm realm = Realm.getInstance(realmConfig);
            try {
                realm.removeAllChangeListeners();
                fail("Should not be able to invoke removeChangeListener");
            } catch (IllegalStateException ignored) {
            } finally {
                realm.close();
                signalTestFinished.countDown();
            }
        }
    });
    thread.start();

    try {
        TestHelper.awaitOrFail(signalTestFinished);
    } finally {
        thread.interrupt();
    }
}
 
開發者ID:weiwenqiang,項目名稱:GitHub,代碼行數:26,代碼來源:RealmTests.java

示例4: waitForChange_runWithRealmThread

import java.util.concurrent.CountDownLatch; //導入方法依賴的package包/類
@Test
public void waitForChange_runWithRealmThread() throws InterruptedException {
    final CountDownLatch bgRealmStarted = new CountDownLatch(1);
    final CountDownLatch bgRealmFished = new CountDownLatch(1);
    final AtomicBoolean bgRealmChangeResult = new AtomicBoolean(false);
    final AtomicLong bgRealmResultSize = new AtomicLong(0);

    RealmThread thread = new RealmThread(realmConfig, new RealmThread.RealmRunnable() {
        @Override
        public void run(Realm realm) {
            bgRealmStarted.countDown();
            bgRealmChangeResult.set(realm.waitForChange());
            bgRealmResultSize.set(realm.where(AllTypes.class).count());
            realm.close();
            bgRealmFished.countDown();
        }
    });
    thread.start();

    TestHelper.awaitOrFail(bgRealmStarted);
    populateTestRealm();
    TestHelper.awaitOrFail(bgRealmFished);
    assertTrue(bgRealmChangeResult.get());
    assertEquals(TEST_DATA_SIZE, bgRealmResultSize.get());
}
 
開發者ID:weiwenqiang,項目名稱:GitHub,代碼行數:26,代碼來源:RealmTests.java

示例5: countDownCallback

import java.util.concurrent.CountDownLatch; //導入方法依賴的package包/類
private Callback<Object> countDownCallback(final CountDownLatch latch) {
  return new Callback<Object>("countDown") {
    @Override void call(Object listener) {
      latch.countDown();
    }
  };
}
 
開發者ID:paul-hammant,項目名稱:googles-monorepo-demo,代碼行數:8,代碼來源:ListenerCallQueueTest.java

示例6: notifyMonitorToStop

import java.util.concurrent.CountDownLatch; //導入方法依賴的package包/類
public void notifyMonitorToStop(CountDownLatch stopSignal) {
if ((monitorThread != null) && monitorThread.isAlive()) {
    ((MockMonitor) users[0]).setStopFlag(stopSignal);
} else {
    stopSignal.countDown();
}
   }
 
開發者ID:lamsfoundation,項目名稱:lams,代碼行數:8,代碼來源:MonitorTest.java

示例7: testThenComposeAsync

import java.util.concurrent.CountDownLatch; //導入方法依賴的package包/類
public void testThenComposeAsync() throws Exception {
    // Composing CompletableFuture is complete
    CompletableFuture<String> cf1 = CompletableFuture.completedFuture("one");

    // Composing function returns a CompletableFuture executed asynchronously
    CountDownLatch cdl = new CountDownLatch(1);
    CompletableFuture<String> cf2 = cf1.thenCompose(str -> CompletableFuture.supplyAsync(() -> {
        while (true) {
            try {
                cdl.await();
                break;
            }
            catch (InterruptedException e) {
            }
        }
        return str + ", two";
    }));

    // Ensure returned CompletableFuture completes after call to thenCompose
    // This guarantees that any premature internal completion will be
    // detected
    cdl.countDown();

    String val = cf2.get();
    Assert.assertNotNull(val);
    Assert.assertEquals(val, "one, two");
}
 
開發者ID:lambdalab-mirror,項目名稱:jdk8u-jdk,代碼行數:28,代碼來源:ThenComposeAsyncTest.java

示例8: waitForChange_interruptingThread

import java.util.concurrent.CountDownLatch; //導入方法依賴的package包/類
@Test
public void waitForChange_interruptingThread() throws InterruptedException {
    final CountDownLatch bgRealmOpened = new CountDownLatch(1);
    final CountDownLatch bgRealmClosed = new CountDownLatch(1);
    final AtomicReference<Boolean> bgRealmWaitResult = new AtomicReference<Boolean>();
    final AtomicReference<Realm> bgRealm = new AtomicReference<Realm>();

    // Waits in background.
    Thread thread = new Thread(new Runnable() {
        @Override
        public void run() {
            Realm realm = Realm.getInstance(realmConfig);
            bgRealm.set(realm);
            bgRealmOpened.countDown();
            bgRealmWaitResult.set(realm.waitForChange());
            realm.close();
            bgRealmClosed.countDown();
        }
    });
    thread.start();

    TestHelper.awaitOrFail(bgRealmOpened);
    // Makes sure background thread goes to wait.
    Thread.sleep(500);
    // Interrupting a thread should neither cause any side effect nor terminate the Background Realm from waiting.
    thread.interrupt();
    assertTrue(thread.isInterrupted());
    assertEquals(null, bgRealmWaitResult.get());

    // Now we'll stop realm from waiting.
    bgRealm.get().stopWaitForChange();
    TestHelper.awaitOrFail(bgRealmClosed);
    assertFalse(bgRealmWaitResult.get());
}
 
開發者ID:weiwenqiang,項目名稱:GitHub,代碼行數:35,代碼來源:RealmTests.java

示例9: multipleInstancesTest

import java.util.concurrent.CountDownLatch; //導入方法依賴的package包/類
@Test
public void multipleInstancesTest() throws InterruptedException {
    final Set<String> ids = Collections.synchronizedSet(new HashSet<String>());
    final int threadCount = 20;
    final int iterationCount = 10000;
    final CountDownLatch latch = new CountDownLatch(threadCount);

    for (int i = 0; i < threadCount; i++) {
        Thread t = new Thread(new Runnable() {
            @Override
            public void run() {
                IDGenerator generator = LocalUniqueIDGeneratorFactory.generatorFor(1, 1);
                try {
                    for (int i = 0; i < iterationCount; i++) {
                        byte[] id = generator.generate();
                        String asHex = Hex.encodeHexString(id);
                        ids.add(asHex);
                    }
                } catch (GeneratorException e) {
                    e.printStackTrace();
                }
                latch.countDown();
            }
        });
        t.start();
    }

    boolean successfullyUnlatched = latch.await(20, TimeUnit.SECONDS);
    assertThat(successfullyUnlatched, is(true));

    assertThat(ids.size(), is(threadCount * iterationCount));
}
 
開發者ID:warlock-china,項目名稱:azeroth,代碼行數:33,代碼來源:UniqueIDGeneratorThreadSafetyIT.java

示例10: testUninterruptible

import java.util.concurrent.CountDownLatch; //導入方法依賴的package包/類
@Test public void testUninterruptible() throws InterruptedException {
  assumeFalse(threading == Threading.DIRECT);
  assumeTrue(mode == Mode.UNINTERRUPTIBLY);
  maxInFlight = 2;
  List<Integer> numbers = asList(1, 2, 3, 4, 5);
  CountDownLatch allowTranslation = new CountDownLatch(1);
  Thread thread = new Thread(() -> {
    try {
      parallelize(numbers.stream(), input -> {
        try {
          allowTranslation.await();
        } catch (InterruptedException e) {
          thrown.add(e);
          return;
        }
        translateToString(input);
      });
    } catch (InterruptedException | TimeoutException impossible) {
      thrown.add(impossible);
    }
  });
  thread.start();
  thread.interrupt();
  assertThat(translated).isEmpty();
  allowTranslation.countDown();
  thread.join();
  // Even interrupted, all numbers should be printed.
  assertThat(translated).containsExactlyEntriesIn(mapToString(numbers));
}
 
開發者ID:google,項目名稱:mug,代碼行數:30,代碼來源:ParallelizerTest.java

示例11: testDelayedAllocation

import java.util.concurrent.CountDownLatch; //導入方法依賴的package包/類
/**
 * Test that delayed allocation blocks
 */
@Test
public void testDelayedAllocation() throws Exception {
    BufferPool pool = new BufferPool(5 * 1024, 1024, metrics, time, metricGroup);
    ByteBuffer buffer = pool.allocate(1024, maxBlockTimeMs);
    CountDownLatch doDealloc = asyncDeallocate(pool, buffer);
    CountDownLatch allocation = asyncAllocate(pool, 5 * 1024);
    assertEquals("Allocation shouldn't have happened yet, waiting on memory.", 1L, allocation.getCount());
    doDealloc.countDown(); // return the memory
    assertTrue("Allocation should succeed soon after de-allocation", allocation.await(1, TimeUnit.SECONDS));
}
 
開發者ID:YMCoding,項目名稱:kafka-0.11.0.0-src-with-comment,代碼行數:14,代碼來源:BufferPoolTest.java

示例12: testCloseWaitsForAbort

import java.util.concurrent.CountDownLatch; //導入方法依賴的package包/類
@Test
public void testCloseWaitsForAbort() throws Exception {
	final CountDownLatch closing = new CountDownLatch(1);
	final CountDownLatch closed = new CountDownLatch(1);
	final AtomicBoolean transactionFinished = new AtomicBoolean(false);
	final AtomicBoolean error = new AtomicBoolean(false);
	final Database<Connection> db = open(false);

	// Start a transaction
	Connection txn = db.startTransaction();
	// In another thread, close the database
	Thread close = new Thread() {
		@Override
		public void run() {
			try {
				closing.countDown();
				db.close();
				if (!transactionFinished.get()) error.set(true);
				closed.countDown();
			} catch (Exception e) {
				error.set(true);
			}
		}
	};
	close.start();
	closing.await();
	// Do whatever the transaction needs to do
	Thread.sleep(10);
	transactionFinished.set(true);
	// Abort the transaction
	db.abortTransaction(txn);
	// The other thread should now terminate
	assertTrue(closed.await(5, SECONDS));
	// Check that the other thread didn't encounter an error
	assertFalse(error.get());
}
 
開發者ID:rafjordao,項目名稱:Nird2,代碼行數:37,代碼來源:H2DatabaseTest.java

示例13: monitorExecutorService

import java.util.concurrent.CountDownLatch; //導入方法依賴的package包/類
@Test
public void monitorExecutorService() throws InterruptedException {
    CountDownLatch taskStart = new CountDownLatch(1);
    CountDownLatch taskComplete = new CountDownLatch(1);

    ThreadPoolTaskExecutor pool = ThreadPoolTaskExecutorMetrics.monitor(registry, "beep.pool", userTags);
    pool.setMaxPoolSize(1);
    pool.setAwaitTerminationSeconds(1);
    pool.setWaitForTasksToCompleteOnShutdown(true);
    pool.initialize();
    pool.submit(() -> {
        taskStart.countDown();
        taskComplete.await(1, TimeUnit.SECONDS);
        System.out.println("beep");
        return 0;
    });
    pool.submit(() -> System.out.println("boop"));

    taskStart.await(1, TimeUnit.SECONDS);
    assertThat(registry.mustFind("beep.pool.queued").tags(userTags).gauge().value()).isEqualTo(1.0);

    taskComplete.countDown();
    pool.shutdown();

    assertThat(registry.mustFind("beep.pool").tags(userTags).timer().count()).isEqualTo(2L);
    assertThat(registry.mustFind("beep.pool.queued").tags(userTags).gauge().value()).isEqualTo(0.0);
}
 
開發者ID:micrometer-metrics,項目名稱:micrometer,代碼行數:28,代碼來源:ThreadPoolTaskExecutorMetricsTest.java

示例14: testNonResponding

import java.util.concurrent.CountDownLatch; //導入方法依賴的package包/類
/**
 * Test of nonResponding method, of class SwingWorker.
 */
@Test
public void testNonResponding() throws Exception {
    System.out.println("nonResponding");
    final boolean[] waiting = new boolean[]{false};
    final CountDownLatch latch = new CountDownLatch(1);
    SwingWorker instance = new SwingWorkerImpl(500, true, null, new Runnable() {
        @Override
        public void run() {
            try {
                Thread.sleep(2000);
            } catch (InterruptedException e) {
            }
        }
    }, new Runnable() {

        @Override
        public void run() {
            latch.countDown();
        }
    }, null, 
    new Runnable() {

        @Override
        public void run() {
            waiting[0] = true;
        }
    });
    instance.execute();
    latch.await(4, TimeUnit.SECONDS);
    
    assertTrue(waiting[0]);
}
 
開發者ID:apache,項目名稱:incubator-netbeans,代碼行數:36,代碼來源:SwingWorkerTest.java

示例15: testTransformAsync_asyncFunction_cancelledBeforeApplyingFunction

import java.util.concurrent.CountDownLatch; //導入方法依賴的package包/類
@GwtIncompatible // threads

  public void testTransformAsync_asyncFunction_cancelledBeforeApplyingFunction()
      throws InterruptedException {
    final AtomicBoolean functionCalled = new AtomicBoolean();
    AsyncFunction<String, Integer> function = new AsyncFunction<String, Integer>() {
      @Override
      public ListenableFuture<Integer> apply(String input) throws Exception {
        functionCalled.set(true);
        return immediateFuture(1);
      }
    };
    SettableFuture<String> inputFuture = SettableFuture.create();
    ExecutorService executor = newSingleThreadExecutor();
    ListenableFuture<Integer> future = transformAsync(
        inputFuture, function, executor);

    // Pause the executor.
    final CountDownLatch beforeFunction = new CountDownLatch(1);
    @SuppressWarnings("unused") // go/futurereturn-lsc
    Future<?> possiblyIgnoredError =
        executor.submit(
            new Runnable() {
              @Override
              public void run() {
                awaitUninterruptibly(beforeFunction);
              }
            });

    // Cancel the future after making input available.
    inputFuture.set("value");
    future.cancel(false);

    // Unpause the executor.
    beforeFunction.countDown();
    executor.awaitTermination(5, SECONDS);

    assertFalse(functionCalled.get());
  }
 
開發者ID:zugzug90,項目名稱:guava-mock,代碼行數:40,代碼來源:FuturesTest.java


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