ExecutorService在调用线程中运行任务?

时间:2012-08-13 20:15:41

标签: java threadpool executorservice

是否有任何java.util.ExecutorService实现只是在调用线程中运行所有已执行的任务?如果默认情况下这不包含在Java中,那么是否有一个包含这样的实现的库?

3 个答案:

答案 0 :(得分:5)

您可以使用Guava com.google.common.util.concurrent.MoreExecutors.sameThreadExecutor(),它可以完全按照您的要求执行:https://github.com/google/guava/blob/0434c5199c83c3f43b8b6a86c62e121d518fe7d0/guava/src/com/google/common/util/concurrent/MoreExecutors.java#L267

编辑:该方法已重命名为com.google.common.util.concurrent.MoreExecutors.newDirectExecutorService() https://github.com/google/guava/blob/f67ab864bde63fa6602b5688de0440957ffeaa2e/guava/src/com/google/common/util/concurrent/MoreExecutors.java#L369

答案 1 :(得分:2)

我能找到的唯一现有实现是SynchronousExecutorService - 遗憾的是,它隐藏在库中。

在此处粘贴源代码(不带注释)以供将来参考:

package org.apache.camel.util.concurrent;

import java.util.List;
import java.util.concurrent.AbstractExecutorService;
import java.util.concurrent.TimeUnit;

public class SynchronousExecutorService extends AbstractExecutorService {

    private volatile boolean shutdown;

    public void shutdown() {
        shutdown = true;
    }

    public List<Runnable> shutdownNow() {
        return null;
    }

    public boolean isShutdown() {
        return shutdown;
    }

    public boolean isTerminated() {
        return shutdown;
    }

    public boolean awaitTermination(long time, TimeUnit unit) throws InterruptedException {
        return true;
    }

    public void execute(Runnable runnable) {
        runnable.run();
    }

}

答案 2 :(得分:0)

你看过java.util.concurrent.ThreadPoolExecutor吗?