本文整理匯總了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.");
}
}
示例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
}
}
}
示例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;
}
示例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;
}
示例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;
}
示例6: cancel
import java.util.concurrent.Future; //導入方法依賴的package包/類
@Override public void cancel() {
canceled = true;
Future<?> task = this.task;
if (task != null) {
task.cancel(true);
}
}
示例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);
}
}
}
示例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);
}
}
示例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);
}
示例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);
}
示例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) {}
}
示例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);
}
}
}
}
示例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);
}
示例14: maybePropagateCancellation
import java.util.concurrent.Future; //導入方法依賴的package包/類
final void maybePropagateCancellation(@Nullable Future<?> related) {
if (related != null & isCancelled()) {
related.cancel(wasInterrupted());
}
}
示例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);
}