Я пытаюсь понять приведенную ниже примерную реализацию интерфейса java.util.concurrent.Executor
, представленную в его API.Интерфейс Java Executor Пример реализации из «API-интерфейса 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);
}
}
}
Здесь проходил Runnable экземпляр заворачивают в другой Runnable экземпляр и хранится в очереди задач, а затем scheduleNext()
вызывается. Является ли переданный экземпляр Runnable скопированным (защищенным) экземпляром другого Runnable? Если нет, то зачем это делать, кроме как выполнить следующие Runnables из очереди?
Просьба уточнить мои сомнения.
Я не понимаю вашего намерения «продуктивного использования» и «управления очередью». –
Ну, управление очередью не является «продуктивным» для вашего приложения. Это накладные расходы. В идеале вы хотите тратить ресурсы только на код внутри вашего Runnable. – Thilo
Спасибо за вашу ясность. Теперь я понял. Есть ли какие-либо проблемы, если я просто добавляю переданный Runnable в очередь, вместо того, чтобы переносить его в другой Runnable. –