Существуют ли какие-либо реализации java.util.ExecutorService
, которые просто запускают все выполняемые задачи в вызывающем потоке? Если это не включено в Java по умолчанию, существует ли библиотека, содержащая подобную реализацию?
ExecutorService, который запускает задачи в вызывающем потоке?
Ответы (3)
Единственная существующая реализация, которую я смог найти, это SynchronousExecutorService
— к сожалению, похоронен где-то в camel.
Вставка исходного кода (без комментариев) здесь для дальнейшего использования:
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();
}
}
execute
.
- person obataku; 14.08.2012
Вы можете использовать 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
вы смотрели на java.util.concurrent.ThreadPoolExecutor?
Executor
; увидеть ихDirectExecutor
? Приложив немного усилий, вы можете превратить его вExecutorService
. - person obataku   schedule 14.08.2012