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


Java CompletableFuture.exceptionally方法代碼示例

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


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

示例1: forwardExceptionShouldPropagate

import java.util.concurrent.CompletableFuture; //導入方法依賴的package包/類
@Test
public void forwardExceptionShouldPropagate() throws Exception {
    final String value = UUID.randomUUID().toString();

    SettableFuture<String> lf = SettableFuture.create();
    CompletableFuture<String> cf = MoreFutures.toCompletableFuture(lf);

    Exception intentionalException = new IntentionalException();
    final AtomicReference<Throwable> foundException = new AtomicReference<>();

    cf = cf.exceptionally(ex -> {
        foundException.set(ex);
        return value;
    });

    lf.setException(intentionalException);

    assertThat(cf).isDone();
    assertThat(cf).isNotCancelled();
    assertThat(cf).isNotCompletedExceptionally();

    assertThat(cf).isCompletedWithValue(value);
    assertThat(foundException.get()).isSameAs(intentionalException);
}
 
開發者ID:salesforce,項目名稱:grpc-java-contrib,代碼行數:25,代碼來源:ToCompletableFutureTest.java

示例2: testExceptionally_normalCompletion

import java.util.concurrent.CompletableFuture; //導入方法依賴的package包/類
/**
 * exceptionally action is not invoked when source completes
 * normally, and source result is propagated
 */
public void testExceptionally_normalCompletion() {
    for (boolean createIncomplete : new boolean[] { true, false })
    for (Integer v1 : new Integer[] { 1, null })
{
    final AtomicInteger a = new AtomicInteger(0);
    final CompletableFuture<Integer> f = new CompletableFuture<>();
    if (!createIncomplete) assertTrue(f.complete(v1));
    final CompletableFuture<Integer> g = f.exceptionally
        ((Throwable t) -> {
            a.getAndIncrement();
            threadFail("should not be called");
            return null;            // unreached
        });
    if (createIncomplete) assertTrue(f.complete(v1));

    checkCompletedNormally(g, v1);
    checkCompletedNormally(f, v1);
    assertEquals(0, a.get());
}}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:24,代碼來源:CompletableFutureTest.java

示例3: testExceptionally_exceptionalCompletion

import java.util.concurrent.CompletableFuture; //導入方法依賴的package包/類
/**
 * exceptionally action completes with function value on source
 * exception
 */
public void testExceptionally_exceptionalCompletion() {
    for (boolean createIncomplete : new boolean[] { true, false })
    for (Integer v1 : new Integer[] { 1, null })
{
    final AtomicInteger a = new AtomicInteger(0);
    final CFException ex = new CFException();
    final CompletableFuture<Integer> f = new CompletableFuture<>();
    if (!createIncomplete) f.completeExceptionally(ex);
    final CompletableFuture<Integer> g = f.exceptionally
        ((Throwable t) -> {
            ExecutionMode.SYNC.checkExecutionMode();
            threadAssertSame(t, ex);
            a.getAndIncrement();
            return v1;
        });
    if (createIncomplete) f.completeExceptionally(ex);

    checkCompletedNormally(g, v1);
    assertEquals(1, a.get());
}}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:25,代碼來源:CompletableFutureTest.java

示例4: testExceptionally_exceptionalCompletionActionFailed

import java.util.concurrent.CompletableFuture; //導入方法依賴的package包/類
/**
 * If an "exceptionally action" throws an exception, it completes
 * exceptionally with that exception
 */
public void testExceptionally_exceptionalCompletionActionFailed() {
    for (boolean createIncomplete : new boolean[] { true, false })
{
    final AtomicInteger a = new AtomicInteger(0);
    final CFException ex1 = new CFException();
    final CFException ex2 = new CFException();
    final CompletableFuture<Integer> f = new CompletableFuture<>();
    if (!createIncomplete) f.completeExceptionally(ex1);
    final CompletableFuture<Integer> g = f.exceptionally
        ((Throwable t) -> {
            ExecutionMode.SYNC.checkExecutionMode();
            threadAssertSame(t, ex1);
            a.getAndIncrement();
            throw ex2;
        });
    if (createIncomplete) f.completeExceptionally(ex1);

    checkCompletedWithWrappedException(g, ex2);
    checkCompletedExceptionally(f, ex1);
    assertEquals(1, a.get());
}}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:26,代碼來源:CompletableFutureTest.java

示例5: exchange

import java.util.concurrent.CompletableFuture; //導入方法依賴的package包/類
/**
 * Start a key exchange process
 * 
 * @param groupId
 *            the id of the group for which a key exchange will be initiated
 * @param aHandler
 *            the handler which succeeds or fails in accordance to the key
 *            exchange outcome
 * @return A Future representation of the key
 */
public CompletableFuture<BigInteger> exchange(int groupId, Handler<AsyncResult<BigInteger>> aHandler) {
    conf.getLogger().info(getNode().toString() + Constants.NEGO_CALL + groupId);
    Group g = groupMappings.get(groupId);
    ExchangeState state = stateMappings.get(groupId);
    state.registerHandler(aHandler);
    CompletableFuture<Void> res = broadcast(g);
    CompletableFuture<BigInteger> future = res.thenCompose(s -> compute(g));
    long timer[] = new long[1];
    timer[0] = vertx.setTimer(conf.getExchangeTimeout(), id -> {
        if (future.isDone() && !future.isCompletedExceptionally()) {
            aHandler.handle(Future.succeededFuture());
            vertx.cancelTimer(timer[0]);
        } else {
            aHandler.handle(Future.failedFuture(Constants.EXCEPTIONTIMEOUTEXCEEDED + Constants.NEGO_TIMEOUT));
            future.completeExceptionally(
                    new TimeoutException(Constants.EXCEPTIONTIMEOUTEXCEEDED + conf.getExchangeTimeout()));
            vertx.cancelTimer(timer[0]);
        }
    });
    future.exceptionally(e -> {
        aHandler.handle(Future.failedFuture(e.getMessage()));
        vertx.cancelTimer(timer[0]);
        return future.join();
    });

    return future;
}
 
開發者ID:maxamel,項目名稱:GDH,代碼行數:38,代碼來源:GDHVertex.java

示例6: createAndStartContainer

import java.util.concurrent.CompletableFuture; //導入方法依賴的package包/類
private String createAndStartContainer(CreateContainerCmd cmd, PullStrategy pullStrategy, DockerClient client) {
	CompletableFuture<String> respFut = new CompletableFuture<>();
	ListImagesCmd imagesCmd = client.listImagesCmd().withImageNameFilter(cmd.getImage());
	List<Image> imagesList = imagesCmd.exec();
	boolean imageAbsent = imagesList == null || imagesList.size() == 0;
	CompletableFuture<Void> pullFut;
	if(imageAbsent || pullStrategy.equals(PullStrategy.ALWAYS)) {
		pullFut = pullImage(cmd, client);
	} else {
		pullFut = CompletableFuture.completedFuture(null);
	}
	
	pullFut
		.exceptionally(ex -> {
			logger.warning("An error occurred while executing a docker pull operation: " + ex.getMessage());
			return null;
		}).thenRun(() -> {
			String containerId = startContainer(cmd, client);
			respFut.complete(containerId);
		})
		.exceptionally(ex -> {
			respFut.completeExceptionally(ex.getCause());
			return null;
		});
	respFut.exceptionally(ex -> {
		logger.severe("Cannot create container. Reason: " + ex.getMessage());
		return null;
	});
	return respFut.join();
}
 
開發者ID:qzagarese,項目名稱:dockerunit,代碼行數:31,代碼來源:DefaultServiceBuilder.java

示例7: performQuerying

import java.util.concurrent.CompletableFuture; //導入方法依賴的package包/類
private <T> T performQuerying(String serviceName, int expectedRecords, int timeoutInSeconds, int frequencyInSeconds,
		BiConsumer<CompletableFuture<T>, Throwable> errorConsumer,
		BiConsumer<CompletableFuture<T>, List<SrvRecord>> matchingConsumer) {
	CompletableFuture<T> result = new CompletableFuture<>();
	final AtomicInteger counter = new AtomicInteger(0);
	vertx.setPeriodic(frequencyInSeconds * 1000, timerId -> {
		dnsClient.resolveSRV(serviceName, ar -> {
			int counterValue = counter.incrementAndGet();
			if (ar.succeeded()) {
				if (ar.result().size() == expectedRecords) {
					vertx.cancelTimer(timerId);
					matchingConsumer.accept(result, ar.result());
				} else {
					if (timedout(timeoutInSeconds, frequencyInSeconds, counterValue)) {
						vertx.cancelTimer(timerId);
						result.completeExceptionally(new RuntimeException("Discovery timed out."));
					}
				}
			} else {
				if (timedout(timeoutInSeconds, frequencyInSeconds, counterValue)) {
					vertx.cancelTimer(timerId);
					result.completeExceptionally(new RuntimeException("Discovery timed out", ar.cause()));
				} else {
					errorConsumer.accept(result, ar.cause());
				}
			}
		});

	});
	result.exceptionally(ex -> {
		throw new RuntimeException("Discovery/cleanup failed for service " + serviceName);
	});
	return result.join();
}
 
開發者ID:qzagarese,項目名稱:dockerunit,代碼行數:35,代碼來源:DnsResolver.java

示例8: testCompletionStage_exceptionally_wraps

import java.util.concurrent.CompletableFuture; //導入方法依賴的package包/類
@Test public void testCompletionStage_exceptionally_wraps() throws Exception {
  CompletableFuture<String> future = new CompletableFuture<>();
  MyException exception = new MyException("test");
  future.completeExceptionally(exception);
  CompletionStage<String> stage = future.exceptionally(e -> {
    throw new CompletionException(e);
  });
  assertCauseOf(ExecutionException.class, stage).isSameAs(exception);
}
 
開發者ID:google,項目名稱:mug,代碼行數:10,代碼來源:MaybeTest.java


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