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


Java Future.cancel方法代碼示例

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


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

示例1: shutdownAndCancelTask

import java.util.concurrent.Future; //導入方法依賴的package包/類
private static void shutdownAndCancelTask(ExecutorService execService, int shutdownDelaySec, String name, Future future) {
    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...");
            if (future != null && !future.isDone() && !future.isCancelled()) {
                System.out.println("Cancelling task " + name + "...");
                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,代碼行數:21,代碼來源:Chapter07Concurrency03.java

示例2: testDrainTimesOut

import java.util.concurrent.Future; //導入方法依賴的package包/類
private void testDrainTimesOut(BlockingQueue<Object> q) throws Exception {
  for (boolean interruptibly : new boolean[] {true, false}) {
    assertEquals(0, Queues.drain(q, ImmutableList.of(), 1, 10, MILLISECONDS));

    Producer producer = new Producer(q, 1);
    // producing one, will ask for two
    Future<?> producerThread = threadPool.submit(producer);
    producer.beganProducing.await();

    // make sure we time out
    Stopwatch timer = Stopwatch.createStarted();

    int drained = drain(q, newArrayList(), 2, 10, MILLISECONDS, interruptibly);
    assertThat(drained).isAtMost(1);

    assertThat(timer.elapsed(MILLISECONDS)).isAtLeast(10L);

    // If even the first one wasn't there, clean up so that the next test doesn't see an element.
    producerThread.cancel(true);
    producer.doneProducing.await();
    if (drained == 0) {
      q.poll(); // not necessarily there if producer was interrupted
    }
  }
}
 
開發者ID:zugzug90,項目名稱:guava-mock,代碼行數:26,代碼來源:QueuesTest.java

示例3: sendEzspTransaction

import java.util.concurrent.Future; //導入方法依賴的package包/類
/**
 * Sends an EZSP request to the NCP and waits for the response. The response is correlated with the request and the
 * returned {@link EzspFrame} contains the request and response data.
 *
 * @param ezspTransaction
 *            Request {@link EzspFrame}
 * @return response {@link EzspFrame}
 */
public EzspTransaction sendEzspTransaction(EzspTransaction ezspTransaction) {
    Future<EzspFrame> futureResponse = sendEzspRequestAsync(ezspTransaction);
    if (futureResponse == null) {
        logger.debug("Error sending EZSP transaction: Future is null");
        return null;
    }

    try {
        futureResponse.get();
        return ezspTransaction;
    } catch (InterruptedException | ExecutionException e) {
        futureResponse.cancel(true);
        logger.debug("EZSP interrupted in sendRequest: ", e);
    }

    return null;
}
 
開發者ID:zsmartsystems,項目名稱:com.zsmartsystems.zigbee,代碼行數:26,代碼來源:AshFrameHandler.java

示例4: timedVirtualMachineCreation

import java.util.concurrent.Future; //導入方法依賴的package包/類
VirtualMachine timedVirtualMachineCreation(Callable<VirtualMachine> creator,
        Callable<Integer> processComplete) throws Exception {
    VirtualMachine result;
    ExecutorService executor = Executors.newCachedThreadPool(runnable -> {
        Thread thread = Executors.defaultThreadFactory().newThread(runnable);
        thread.setDaemon(true);
        return thread;
    });
    try {
        Future<VirtualMachine> future = executor.submit(creator);
        if (processComplete != null) {
            executor.submit(() -> {
                Integer i = processComplete.call();
                future.cancel(true);
                return i;
            });
        }

        try {
            result = future.get(connectTimeout, TimeUnit.MILLISECONDS);
        } catch (TimeoutException ex) {
            future.cancel(true);
            throw ex;
        }
    } finally {
        executor.shutdownNow();
    }
    return result;
}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:30,代碼來源:JdiInitiator.java

示例5: cancelCleanup

import java.util.concurrent.Future; //導入方法依賴的package包/類
private boolean cancelCleanup()
{
	final Future<?> task = _cleanupTask;
	if (task != null)
	{
		_cleanupTask = null;
		return task.cancel(true);
	}
	return false;
}
 
開發者ID:rubenswagner,項目名稱:L2J-Global,代碼行數:11,代碼來源:L2GameClient.java

示例6: cancel

import java.util.concurrent.Future; //導入方法依賴的package包/類
@Override public void cancel() {
  canceled = true;
  Future<?> task = this.task;
  if (task != null) {
    task.cancel(true);
  }
}
 
開發者ID:weiwenqiang,項目名稱:GitHub,代碼行數:8,代碼來源:BehaviorCall.java

示例7: decodePage

import java.util.concurrent.Future; //導入方法依賴的package包/類
public void decodePage(Object decodeKey, int pageNum, final DecodeCallback decodeCallback, float zoom, RectF pageSliceBounds)
{
    final DecodeTask decodeTask = new DecodeTask(pageNum, decodeCallback, zoom, decodeKey, pageSliceBounds);
    synchronized (decodingFutures)
    {
        if (isRecycled) {
            return;
        }
        final Future<?> future = executorService.submit(new Runnable()
        {
            public void run()
            {
                try
                {
                    Thread.currentThread().setPriority(Thread.NORM_PRIORITY-1);
                    performDecode(decodeTask);
                }
                catch (IOException e)
                {
                    Log.e(DECODE_SERVICE, "Decode fail", e);
                }
            }
        });
        final Future<?> removed = decodingFutures.put(decodeKey, future);
        if (removed != null)
        {
            removed.cancel(false);
        }
    }
}
 
開發者ID:lidong1665,項目名稱:AndroidPDF,代碼行數:31,代碼來源:DecodeServiceBase.java

示例8: actionPerformed

import java.util.concurrent.Future; //導入方法依賴的package包/類
public void actionPerformed(ActionEvent e) {
    setEnabled(false); // discourage repeated clicking

    Future<?> actionTask;
    synchronized (this) {
        actionTask = task;
    }

    if (actionTask != null) {
        actionTask.cancel(true);
    }
}
 
開發者ID:apache,項目名稱:incubator-netbeans,代碼行數:13,代碼來源:StopAction.java

示例9: assertThrowInterruptedExceptionWhenInterrupted

import java.util.concurrent.Future; //導入方法依賴的package包/類
void assertThrowInterruptedExceptionWhenInterrupted(Action[] actions) {
    int n = actions.length;
    Future<?>[] futures = new Future<?>[n];
    CountDownLatch threadsStarted = new CountDownLatch(n);
    CountDownLatch done = new CountDownLatch(n);

    for (int i = 0; i < n; i++) {
        Action action = actions[i];
        futures[i] = cachedThreadPool.submit(new CheckedRunnable() {
            public void realRun() throws Throwable {
                threadsStarted.countDown();
                try {
                    action.run();
                    shouldThrow();
                }
                catch (InterruptedException success) {}
                catch (Throwable fail) { threadUnexpectedException(fail); }
                assertFalse(Thread.interrupted());
                done.countDown();
            }});
    }

    await(threadsStarted);
    assertEquals(n, done.getCount());
    for (Future<?> future : futures) // Interrupt all the tasks
        future.cancel(true);
    await(done);
}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:29,代碼來源:StampedLockTest.java

示例10: remove

import java.util.concurrent.Future; //導入方法依賴的package包/類
public void remove(P param) {
    Future<R> f = cache.get(param);

    if (f != null && !f.isDone()) {
        f.cancel(true);
    }

    cache.remove(param);
}
 
開發者ID:apache,項目名稱:incubator-netbeans,代碼行數:10,代碼來源:TasksCachedProcessor.java

示例11: testCannotScheduleLongerThanIntegerMaxValue

import java.util.concurrent.Future; //導入方法依賴的package包/類
public void testCannotScheduleLongerThanIntegerMaxValue() throws Exception {
    Runnable r = new Runnable() {

        @Override
        public void run() {
            fail ("Should not have been run");
        }
    };
    try {
        Future<?> f = RequestProcessor.getDefault().schedule(r, Long.MAX_VALUE, TimeUnit.DAYS);
        f.cancel(true);
    } catch (Exception e) {}
}
 
開發者ID:apache,項目名稱:incubator-netbeans,代碼行數:14,代碼來源:RequestProcessor180386Test.java

示例12: cancel

import java.util.concurrent.Future; //導入方法依賴的package包/類
@Override
public void cancel() {
    super.cancel();
    if (mFutureList != null && !mFutureList.isEmpty()) {
        for (Future future : mFutureList) {
            if (future != null) {
                future.cancel(true);
            }
        }
    }
}
 
開發者ID:ghnor,項目名稱:Flora,代碼行數:12,代碼來源:BatchCompressEngine.java

示例13: destory

import java.util.concurrent.Future; //導入方法依賴的package包/類
public void destory(Long pipelineId) {
    if (!threads.containsKey(pipelineId)) {
        throw new IllegalArgumentException("pipeline is not exist!");
    }

    Future future = threads.get(pipelineId);
    future.cancel(true);
}
 
開發者ID:luoyaogui,項目名稱:otter-G,代碼行數:9,代碼來源:ExtractServiceDemo.java

示例14: maybePropagateCancellation

import java.util.concurrent.Future; //導入方法依賴的package包/類
final void maybePropagateCancellation(@Nullable Future<?> related) {
  if (related != null & isCancelled()) {
    related.cancel(wasInterrupted());
  }
}
 
開發者ID:paul-hammant,項目名稱:googles-monorepo-demo,代碼行數:6,代碼來源:AbstractFuture.java

示例15: stop

import java.util.concurrent.Future; //導入方法依賴的package包/類
@Override
public boolean stop(String entityClassName) {
    Future<?> future = this.inFlightTasksMap.get(entityClassName);
    return future != null && future.cancel(true);
}
 
開發者ID:chaokunyang,項目名稱:jkes,代碼行數:6,代碼來源:ForkJoinIndexer.java


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