几种等待并发线程全部完成的方法

学习到如下几种方法:

1、对于单个的线程,可以采用Future.get()的方法,任务执行完毕后才能拿到结果。

2、对于多个线程,可以采用executor.awaitTemination()的方法,伪代码如下所示:

    for(int i = 0;i < n;i++){

           executor.execute(task(i));

    }

    executor.shutdown();

    executor.awaitTemination(Long.MAX_VALUE,TimeUnit.SECONDS);

3、可以采用闭锁,制造阀门效应,伪代码如下所示:

    #主线程执行

    CountDonwLatch done = new CountDownLatch(n);

    for(int i = 0;i < n;i++){

           executor.execute(task(i));

    }

    done.await();

   

    #多线程任务中执行

    doTask(i);

    done.countDown();

   

你可能感兴趣的:(java,Concurrent)