本文整理匯總了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'});
}
示例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);
}
示例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();
}
}
示例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());
}
示例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();
}
};
}
示例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();
}
}
示例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");
}
示例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());
}
示例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));
}
示例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));
}
示例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));
}
示例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());
}
示例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);
}
示例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]);
}
示例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());
}