zoukankan      html  css  js  c++  java
  • Java如何判断线程池所有任务是否执行完毕

    package csdn;  
      
    import java.util.concurrent.ExecutorService;  
    import java.util.concurrent.Executors;  
      
    /** 
     * @author nineday 
     */  
    public class Test {  
      
        public static void main(String args[]) throws InterruptedException {  
            ExecutorService exe = Executors.newFixedThreadPool(50);  
            for (int i = 1; i <= 5; i++) {  
                exe.execute(new SubThread(i));  
            }  
            exe.shutdown();  
            while (true) {  
                if (exe.isTerminated()) {  
                    System.out.println("结束了!");  
                    break;  
                }  
                Thread.sleep(200);  
            }  
        }  
    }  
    上面是主线程的代码,创建了一个能同时执行2个线程的线程池,并投入5个线程,当5个线程都执行完毕后打印---“结束了!”字符串。
    exe.shutdown();该方法在加入线程队列的线程执行完之前不会执行。


    exe.isTerminated();当shutdown()或者shutdownNow()执行了之后才会执行,并返回true。


    在上面的代码中必须有exe.isTerminated()的判断,否则在投入5个线程到线程池后会直接打印:“结束了”。不能达到我们想要的效果。


    通过while(true)循环判断exe.isTerminated()重生之大文豪的值,为了防止过多的判断浪费资源,可设置线程睡眠Thread.sleep(200);


    正是由于这个睡眠,所以当所有线程池中的线程都执行完后,有可能延迟200ms才执行"结束了"语句。这个参数越小延迟越小,结果越准确。


    下面是子线程,子线程只是简单的将数字i打印出来;


    [java] view plaincopy
    package csdn;  
      
    /** 
     * @author nineday 
     */  
    public class SubThread extends Thread{  
          
        private final int i;  
        public SubThread(int i){  
            this.i = i;  
        }  
        @Override  
        public void run(){  
            System.out.println(i);  
        }  
    }  
    执行结果:


    [plain] view plaincopy
    run:  
    3  
    1  
    4  
    5  
    2  
    结束了!  
    成功构建 (总时间: 2 秒)  
    子线程执行顺序不能控制,所以输出的结果是乱序的。

  • 相关阅读:
    二叉平衡树
    红黑树
    [leetcode] LCP 比赛
    二叉搜索树
    面向对象的二叉树的实现
    二叉树的序列化与反序列化
    [leetcode] 基本计算器
    【pandas】玩转一行拆多行,多行并一行(分分合合你说了算)
    【VBA】数据溢出与解决
    【VBA】criterial 未找到命名参数
  • 原文地址:https://www.cnblogs.com/xxdfly/p/5645144.html
Copyright © 2011-2022 走看看