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