5

java.util.ExecutorService実行されたすべてのタスクを呼び出し元のスレッドで単純に実行する実装はありますか? これがデフォルトでJavaに含まれていない場合、このような実装を含むライブラリはありますか?

4

3 に答える 3

6

Guava com.google.common.util.concurrent.MoreExecutors.sameThreadExecutor() を使用できます。 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

于 2013-01-31T19:37:51.923 に答える
3

私が見つけた唯一の既存の実装は、残念ながらライブラリ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();
    }

}
于 2012-08-13T20:32:37.350 に答える
0

java.util.concurrent.ThreadPoolExecutor を見ましたか?

于 2012-08-13T20:19:51.400 に答える