Spec-Zone .ru
спецификации, руководства, описания, API
|
public interface Executor
Runnable
задачи. Этот интерфейс обеспечивает способ разъединить представление задачи от механики того, как каждая задача будет выполнена, включая детали использования потока, планирования, и т.д. Executor обычно используется вместо того, чтобы явно создать потоки. Например, вместо того, чтобы вызвать new Thread(new(RunnableTask())).start() для каждого ряда задач, Вы могли бы использовать: Executor executor = anExecutor; executor.execute(new RunnableTask1()); executor.execute(new RunnableTask2()); ...Однако, интерфейс Executor строго не требует, чтобы то выполнение было асинхронным. В самом простом случае исполнитель может сразу выполнить представленную задачу в потоке вызывающей стороны:
class DirectExecutor implements Executor { public void execute(Runnable r) { r.run(); } }Более обычно задачи выполняются в некотором потоке кроме потока вызывающей стороны. Исполнитель ниже порождает новый поток для каждой задачи.
class ThreadPerTaskExecutor implements Executor { public void execute(Runnable r) { new Thread(r).start(); } }Много реализаций Executor налагают своего рода ограничение на то, как и когда задачи планируются. Исполнитель ниже сериализирует представление задач второму исполнителю, иллюстрируя составного исполнителя.
class SerialExecutor implements Executor {
final Queue<Runnable> tasks = new ArrayDeque<Runnable>();
final Executor executor;
Runnable active;
SerialExecutor(Executor executor) {
this.executor = executor;
}
public synchronized void execute(final Runnable r) {
tasks.offer(new Runnable() {
public void run() {
try {
r.run();
} finally {
scheduleNext();
}
}
});
if (active == null) {
scheduleNext();
}
}
protected synchronized void scheduleNext() {
if ((active = tasks.poll()) != null) {
executor.execute(active);
}
}
}
Реализации Executor обеспечили в этой реализации пакета ExecutorService
, который является более обширным интерфейсом. ThreadPoolExecutor
класс обеспечивает расширяемую реализацию пула потоков. Executors
класс предоставляет удобные методы фабрики этим Исполнителям. Эффекты непротиворечивости памяти: Действия в потоке до передачи a Runnable
возразите против Executor
произойдите - прежде, чем его выполнение начнется, возможно в другом потоке.
void execute(Runnable command)
command
- выполнимая задачаRejectedExecutionException
- если эта задача не может быть принята для выполнения.NullPointerException
- если команда является нулем
Для дальнейшей ссылки API и документации разработчика, см.
Авторское право © 1993, 2011, Oracle и/или его филиалы. Все права защищены.