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


Java Future.isCancelled方法代碼示例

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


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

示例1: demo1_Executor1

import java.util.concurrent.Future; //導入方法依賴的package包/類
private static void demo1_Executor1() {
    System.out.println();
    int shutdownDelaySec = 1;
    ExecutorService execService = Executors.newSingleThreadExecutor();
    Runnable runnable = () -> System.out.println("Worker One did the job.");
    execService.execute(runnable);
    runnable = () -> System.out.println("Worker Two did the job.");
    Future future = execService.submit(runnable);
    try {
        execService.shutdown();
        execService.awaitTermination(shutdownDelaySec, TimeUnit.SECONDS);
    } catch (Exception ex) {
        System.out.println("Caught around execService.awaitTermination(): " + ex.getClass().getName());
    } finally {
        if (!execService.isTerminated()) {
            if (future != null && !future.isDone() && !future.isCancelled()) {
                System.out.println("Cancelling the task...");
                future.cancel(true);
            }
        }
        List<Runnable> l = execService.shutdownNow();
        System.out.println(l.size() + " tasks were waiting to be executed. Service stopped.");
    }
}
 
開發者ID:PacktPublishing,項目名稱:Java-9-Cookbook,代碼行數:25,代碼來源:Chapter07Concurrency03.java

示例2: printResults

import java.util.concurrent.Future; //導入方法依賴的package包/類
private static void printResults(List<Future<Result>> futures, int timeoutSec) {
    System.out.println("Results from futures:");
    if (futures == null || futures.size() == 0) {
        System.out.println("No results. Futures" + (futures == null ? " = null" : ".size()=0"));
    } else {
        for (Future<Result> future : futures) {
            try {
                if (future.isCancelled()) {
                    System.out.println("Worker is cancelled.");
                } else {
                    Result result = future.get(timeoutSec, TimeUnit.SECONDS);
                    System.out.println("Worker " + result.getWorkerName() + " slept "
                            + result.getSleepSec() + " sec. Result = " + result.getResult());
                }
            } catch (Exception ex) {
                System.out.println("Caught while getting result: " + ex.getClass().getName());
            }
        }
    }
}
 
開發者ID:PacktPublishing,項目名稱:Java-9-Cookbook,代碼行數:21,代碼來源:Chapter07Concurrency03.java

示例3: shutdownAndCancelTasks

import java.util.concurrent.Future; //導入方法依賴的package包/類
private static void shutdownAndCancelTasks(ExecutorService execService, int shutdownDelaySec, List<Future<Result>> futures) {
    try {
        execService.shutdown();
        System.out.println("Waiting for " + shutdownDelaySec + " sec before shutting down service...");
        execService.awaitTermination(shutdownDelaySec, TimeUnit.SECONDS);
    } catch (Exception ex) {
        System.out.println("Caught around execService.awaitTermination(): " + ex.getClass().getName());
    } finally {
        if (!execService.isTerminated()) {
            System.out.println("Terminating remaining running tasks...");
            for (Future<Result> future : futures) {
                if (future.isDone() && !future.isCancelled()) {
                    System.out.println("Cancelling task...");
                    future.cancel(true);
                }
            }
        }
        System.out.println("Calling execService.shutdownNow()...");
        List<Runnable> l = execService.shutdownNow();
        System.out.println(l.size() + " tasks were waiting to be executed. Service stopped.");
    }
}
 
開發者ID:PacktPublishing,項目名稱:Java-9-Cookbook,代碼行數:23,代碼來源:Chapter07Concurrency03.java

示例4: testInvokeAllTimeout

import java.util.concurrent.Future; //導入方法依賴的package包/類
@Test
public void testInvokeAllTimeout() throws Exception {
  final EDTExecutorService ex = new EDTExecutorService();

  final List<Callable<Character>> tasks =
    new ArrayList<Callable<Character>>();
  for (int i = 0; i < 10; ++i) {
    tasks.add(new Callable<Character>() {
      public Character call() {
        assertTrue(SwingUtilities.isEventDispatchThread());
        return 'x';
      }
    });
  }

  for (Future<Character> f : ex.invokeAll(tasks, 1L, TimeUnit.NANOSECONDS)) {
    if (!f.isCancelled()) assertEquals('x', f.get().charValue());
  }
}
 
開發者ID:ajmath,項目名稱:VASSAL-src,代碼行數:20,代碼來源:EDTExecutorServiceTest.java

示例5: tillStop

import java.util.concurrent.Future; //導入方法依賴的package包/類
@Override
protected void tillStop() {
    Future<?> future = this._future;
    if (future == null
            || future.isCancelled()
            || future.isDone()) {
        return;
    }
    try {
        future.get();
    } catch (CancellationException
            | InterruptedException
            | ExecutionException ex) {
        // ignore
    }
}
 
開發者ID:febit,項目名稱:febit,代碼行數:17,代碼來源:ExecutorServiceTaskExecutorFactory.java

示例6: executeTask

import java.util.concurrent.Future; //導入方法依賴的package包/類
public boolean executeTask(Runnable tsk) {
  Future<?> ret;
  
  try {
    theLock.lock();
    ret = worker.submit(tsk);
  } catch(Throwable t) {
    t.printStackTrace();
    return false;
  } finally {
    theLock.unlock();
  }

  try {
    ret.get();
  } catch (Exception e) {
    e.printStackTrace();
    return false;
  }

  if(ret.isCancelled())
    return false;
  return true;
}
 
開發者ID:twosigma,項目名稱:beaker-notebook-archive,代碼行數:25,代碼來源:BeakerCellExecutor.java

示例7: cancelRequest

import java.util.concurrent.Future; //導入方法依賴的package包/類
/**
 * 取消正在執行的或者正在排隊的請求
 *
 * @param requestId
 */
public synchronized void cancelRequest(String requestId) {
    if (TextUtils.isEmpty(requestId)) return;

    List<Future<String>> list = mFutures.get(requestId);
    if (list != null && list.size() > 0) {
        for (Future<String> future : list) {

            Request request = mRequests.remove(future);
            if (request != null) {
                request.setCanceled(true);

                if (request.getCall() != null) {
                    request.getCall().cancel();
                }
            }

            if (future.isDone() || future.isCancelled()) continue;
            future.cancel(true);

        }
        list.clear();
    }

}
 
開發者ID:jessie345,項目名稱:RetrofitAppArchitecture,代碼行數:30,代碼來源:RequestExecutor.java

示例8: leaseConnection

import java.util.concurrent.Future; //導入方法依賴的package包/類
protected HttpClientConnection leaseConnection(
        final Future<CPoolEntry> future,
        final long timeout,
        final TimeUnit tunit) throws InterruptedException, ExecutionException, ConnectionPoolTimeoutException {
    final CPoolEntry entry;
    try {
        entry = future.get(timeout, tunit);
        if (entry == null || future.isCancelled()) {
            throw new InterruptedException();
        }
        Asserts.check(entry.getConnection() != null, "Pool entry with no connection");
        if (this.log.isDebugEnabled()) {
            this.log.debug("Connection leased: " + format(entry) + formatStats(entry.getRoute()));
        }
        return CPoolProxy.newProxy(entry);
    } catch (final TimeoutException ex) {
        throw new ConnectionPoolTimeoutException("Timeout waiting for connection from pool");
    }
}
 
開發者ID:mozilla-mobile,項目名稱:FirefoxData-android,代碼行數:20,代碼來源:PoolingHttpClientConnectionManager.java

示例9: execCancelable

import java.util.concurrent.Future; //導入方法依賴的package包/類
@Nullable
public static <T> T execCancelable(@NotNull final Callable<T> callable) {
  final Future<T> future = ApplicationManager.getApplication().executeOnPooledThread(callable);

  while (!future.isCancelled() && !future.isDone()) {
    ProgressManager.checkCanceled();
    TimeoutUtil.sleep(500);
  }
  T result = null;
  try {
    result = future.get();
  }
  catch (InterruptedException | ExecutionException e) {
    LOG.warn(e.getMessage());
  }
  return result;
}
 
開發者ID:medvector,項目名稱:educational-plugin,代碼行數:18,代碼來源:StudyUtils.java

示例10: handleOneInputDone

import java.util.concurrent.Future; //導入方法依賴的package包/類
/**
 * Handles the input at the given index completing.
 */
private void handleOneInputDone(int index, Future<? extends InputT> future) {
  // The only cases in which this Future should already be done are (a) if it was cancelled or
  // (b) if an input failed and we propagated that immediately because of allMustSucceed.
  checkState(
      allMustSucceed || !isDone() || isCancelled(),
      "Future was done before all dependencies completed");

  try {
    checkState(future.isDone(), "Tried to set value from future which is not done");
    if (allMustSucceed) {
      if (future.isCancelled()) {
        // clear running state prior to cancelling children, this sets our own state but lets
        // the input futures keep running as some of them may be used elsewhere.
        runningState = null;
        cancel(false);
      } else {
        // We always get the result so that we can have fail-fast, even if we don't collect
        InputT result = getDone(future);
        if (collectsValues) {
          collectOneValue(allMustSucceed, index, result);
        }
      }
    } else if (collectsValues && !future.isCancelled()) {
      collectOneValue(allMustSucceed, index, getDone(future));
    }
  } catch (ExecutionException e) {
    handleException(e.getCause());
  } catch (Throwable t) {
    handleException(t);
  }
}
 
開發者ID:paul-hammant,項目名稱:googles-monorepo-demo,代碼行數:35,代碼來源:AggregateFuture.java

示例11: isResultAvailable

import java.util.concurrent.Future; //導入方法依賴的package包/類
public boolean isResultAvailable(final P arg) {
    Future<R> res = cache.get(arg);

    if (res == null) {
        return false;
    }

    return res.isDone() && !res.isCancelled();
}
 
開發者ID:apache,項目名稱:incubator-netbeans,代碼行數:10,代碼來源:TasksCachedProcessor.java

示例12: isCancelled

import java.util.concurrent.Future; //導入方法依賴的package包/類
@Override
public boolean isCancelled() {
	boolean result = false;
	for (Future<Boolean> future : futures) {
		Boolean futureResult = future.isCancelled(); 
		result = result || (futureResult != null ? futureResult : false);			
	}
	return result;
}
 
開發者ID:kefik,項目名稱:Pogamut3,代碼行數:10,代碼來源:CombinedBooleanFuture.java

示例13: cancel

import java.util.concurrent.Future; //導入方法依賴的package包/類
private static void cancel(List<Future<String>> futures) {
    for (Future future : futures) {
        if (!future.isCancelled() && !future.isDone()) {
            future.cancel(true);
        }
    }
}
 
開發者ID:pmohankumar,項目名稱:fibers,代碼行數:8,代碼來源:CompositeFiberCompletionServiceTest.java

示例14: cancel

import java.util.concurrent.Future; //導入方法依賴的package包/類
@Override
public void cancel(Run run) {
	String runId = run.getId();
	Future<?> future = RUNNING.remove(runId);
	if (future == null) {
		return;
	}
	if (future.isDone()) {
		return;
	}
	if (future.isCancelled()) {
		return;
	}
	future.cancel(true);
}
 
開發者ID:Bibliome,項目名稱:alvisnlp,代碼行數:16,代碼來源:ThreadExecutor.java

示例15: cancel

import java.util.concurrent.Future; //導入方法依賴的package包/類
public void cancel() {
    logger.info("canal Futures[{}]", futures.size());
    for (int i = 0; i < futures.size(); i++) {
        Future future = futures.get(i);
        if (!future.isDone() && !future.isCancelled()) {
            future.cancel(true);
        }
    }
}
 
開發者ID:luoyaogui,項目名稱:otter-G,代碼行數:10,代碼來源:ExecutorTemplate.java


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