如何阻止Callable提交给ExecutorService?

时间:2012-07-11 09:24:34

标签: java multithreading

我正在尝试实现一个示例应用程序来测试CallableExecutorService接口。

在我的应用程序中,我已声明:

ExecutorService exSvc = Executors.newSingleThreadExecutor();

然后:

Future<Integer> test = exSvc.submit(
    new Callable<Integer>() {
        public Integer call() {
            for(int i = 0; i < 1000; i++){
                System.out.println(i);
            }
            return 1;
        }
    });

现在我试图在终止之前停止进程,我正在使用exSvc.shutdownNow()但它不起作用。

要优雅地停止经典Thread我通常会使用某种条件变量。遵循ExecutorService的常用方法是什么?

2 个答案:

答案 0 :(得分:16)

Future.cancel(true)ExecutorService.shutdownNow()使用线程中断。只要您不在任务中进行不间断的阻塞调用,您只需要正确处理中断条件,如下所示:

for(int i = 0; i < 1000; i++){
    // Uses isInterrupted() to keep interrupted status set
    if (Thread.currentThread().isInterrupted()) {
        // Cannot use InterruptedException since it's checked
        throw new RuntimeException(); 
    }
    System.out.println(i);
}

如果你进行不间断的阻塞调用(例如网络IO),事情变得更加复杂,你需要以某种方式手动中断它们,例如,通过关闭底层套接字。

答案 1 :(得分:1)

这就是我用FixedThreadPool做的方式,希望它有所帮助。

    ExecutorService pool = Executors.newFixedThreadPool(Runtime.getRuntime().availableProcessors());

    List<Future<Void>> results = new ArrayList<>();

    for (int i = 0; i < numberOfJobs; i++) {
        MyCallableJob job = new MyCallableJob (...);
        results.add(pool.submit(job));
    }

    for (Future<Void> result : results) {
        try { result.get(); }
        catch (InterruptedException | ExecutionException ignorable) { }
    }

    pool.shutdown();