1.判断线程池中所有线程是否执行完毕
import java.util.concurrent.LinkedBlockingQueue;
import java.util.concurrent.ThreadPoolExecutor;
import java.util.concurrent.TimeUnit;
public class ThreadsIsDone {
public static void main(String[] args) {
ThreadPoolExecutor pool = new ThreadPoolExecutor(10, 10, 0L, TimeUnit.MILLISECONDS,
new LinkedBlockingQueue<Runnable>());
for (int i = 0; i < 10; i++) {
pool.submit(new Runnable() {
"当前线程:" + Thread.currentThread().getName() + ",打印随机数:" + new Random().nextInt(1000));
System.out.println("pool.getTaskCount():" + pool.getTaskCount());
System.out.println("pool.getCompletedTaskCount():" + pool.getCompletedTaskCount());
boolean allThreadsIsDone = pool.getTaskCount() == pool.getCompletedTaskCount();
System.out.println(allThreadsIsDone);
System.out.println("全部执行完成");
while (!allThreadsIsDone) {
allThreadsIsDone = pool.getTaskCount() == pool.getCompletedTaskCount();
System.out.println("全部执行完成");
- 当调用ExecutorService的shutdown()和awaitTermination()
import java.util.concurrent.LinkedBlockingQueue;
import java.util.concurrent.ThreadPoolExecutor;
import java.util.concurrent.TimeUnit;
public class ThreadDone {
public static void main(String[] args) {
ThreadPoolExecutor pool = new ThreadPoolExecutor(10, 10, 0L, TimeUnit.MILLISECONDS,
new LinkedBlockingQueue<Runnable>());
for (int i = 0; i < 10; i++) {
pool.submit(new Runnable() {
"当前线程:" + Thread.currentThread().getName() + ",打印随机数:" + new Random().nextInt(1000));
pool.awaitTermination(Long.MAX_VALUE, TimeUnit.DAYS);
} catch (InterruptedException e) {
System.out.println("all thread complete");