У меня есть ConcurrentLinkedDeque, который я использую для синхронных push/pop элементов, и у меня есть некоторые асинхронные задачи, которые берут один элемент из стека, и если этот элемент имеет соседей, он нажимает его на стек.
Пример кода:
private ConcurrentLinkedDeque<Item> stack = new ConcurrentLinkedDeque<>();
private ExecutorService exec = Executors.newFixedThreadPool(5);
while ((item = stack.pollFirst()) != null) {
if (item == null) {
} else {
Runnable worker = new Solider(this, item);
exec.execute(worker);
}
}
class Solider{
public void run(){
if(item.hasNeighbors){
for(Item item:item.neighbors){
stack.push(item)
}
}
}
}
Я хотел бы иметь дополнительную инструкцию в цикле while, которая отвечает на вопрос - "любая работа в Executor работает?"