【问题标题】:Executorservice wait after tasks are finishedExecutorservice 等待任务完成后
【发布时间】:2021-08-14 17:38:28
【问题描述】:

我有这段代码,它的作用是等待所有任务完成,然后才将值返回给小部件。 WorkerThread 是一个可运行对象,需要在下一个循环之前完成。

final ScheduledExecutorService ecs = Executors.newScheduledThreadPool(size2/2);
while(size2>1) {
    for (int i = 0; i < size2/2; i++) {
        Runnable worker = null;
        try {
            worker = new WorkerThread(players.take(), players.take() ,area,players);
        } catch (InterruptedException interruptedException) {
            interruptedException.printStackTrace();
        }
        ecs.submit(worker);
    }
    area.append("\n\n next Round");
    size2=size2/2;
}

所以我需要做的是在这种情况下完成 8 个任务,获取它们附加到小部件的值,然后等待例如 2 秒,现在继续执行 4 个任务的循环。

【问题讨论】:

    标签: java threadpool executorservice runnable


    【解决方案1】:

    您可以使用Phaser

    Phaser phaser = new Phaser(1); // Create Phaser instance
    final ScheduledExecutorService ecs = Executors.newScheduledThreadPool(size2/2);
    while(size2>1) {
        for (int i = 0; i < size2/2; i++) {
            Runnable worker = null;
            try {
                worker = new WorkerThread(players.take(), players.take() ,area,players);
            } catch (InterruptedException interruptedException) {
                interruptedException.printStackTrace();
            }
            phaser.register(); // Register a party
            ecs.submit(worker);
        }
        phaser.arriveAndAwaitAdvance(); // Wait for completion of all tasks
        area.append("\n\n next Round");
        size2=size2/2;
    }
    

    这是你的消费者。

    public class WorkerThread {
    
        public WorkerThread(Phaser phaser) {
            this.phaser = phaser;
        }
    
        public void run() {
            processThings();
            phaser.arriveAndDeregister(); // Deregister a party
        }
    
    }
    

    【讨论】:

      猜你喜欢
      • 2011-03-17
      • 1970-01-01
      • 1970-01-01
      • 2018-09-22
      • 2020-03-15
      • 2016-09-10
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多