Chinaunix首页 | 论坛 | 博客
  • 博客访问: 32406
  • 博文数量: 18
  • 博客积分: 0
  • 博客等级: 民兵
  • 技术积分: 122
  • 用 户 组: 普通用户
  • 注册时间: 2013-12-05 16:09
文章分类
文章存档

2014年(6)

2013年(12)

我的朋友

分类: Java

2014-01-05 16:57:05

[java] view plaincopy
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 秒)  
子线程执行顺序不能控制,所以输出的结果是乱序的。
阅读(9580) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~