Я хочу создать свой собственный ExecutorService на Java, который способен «отправлять (вызываемая задача)» заданную задачу.
Я намеревался использовать пул потоков, состоящий из нескольких потоков (Runnable target).
Идея состоит в том, чтобы создать фиксированное количество потоков, которые удаляют объекты FutureTask из списка, который был заполнен методом submit. Объекты FutureTask также были созданы в методе submit.
Моя проблема в том, что я могу передать объект Runnable (здесь: FutureTask) только потоку при создании потока (через конструктор), но очевидно, что FutureTasks нужно назначать потоку динамически (когда элемент удаляется из списка ).
Есть ли способ сделать это?
// content of submit, parameter: myTask
FutureTask<V> newFutureTask = new FutureTask<V>(myTask);
taskQueue = new BlockingQueue<FutureTask<V>>();
try {
taskQueue.put(newFutureTask);
} catch (InterruptedException ex) { }
return newFutureTask;
// remove item from list and hand it over to thread
// method within MyThread extends Thread (thread pool) class
void exec() {
FutureTask<V> task;
try {
task = taskQueue.take();
// TODO: run task somehow????
} catch(InterruptedException ex) { }
}