ThreadPoolTaskExecutor的常见问题

spring的ThreadPoolTaskExecutor使用可以参考http://kim-miao.iteye.com/blog/1310015。

1.用junit跑测试用例,为什么用ThreadPoolTaskExecutor,里面的代码不执行了。看下下面代码:

 private Executor priceSyncExecutor = context.getBean("priceSyncExecutor",Executor.class);
try{
     for(int i = 0; i < 100;i++) {
                final int j = i;
                priceSyncExecutor.execute(new Runnable() {
                    @Override
                    public void run() {
                        method1(j);
                    }
                });
            }
            Thread.sleep(5000L);
}catch(Exception e){
  e.printStackTrace();
}

 public void method1(int i){
        try{
            Thread.sleep(1000L);
            System.out.println(i);
        }catch(Exception e){
            e.printStackTrace();
        }
    }

 代码比较简单,如果没有主方法的Thread.sleep(5000L),可能一个print都没有打出来。

改变5000L的值,打印的行数也不一样。这个主要是由于executor.execute() 激活的线程都是守护线程,主线程结束,守护线程就会放弃执行,这个在业务中式符合逻辑的,在单元测试中为了看到执行效果,需要自行阻塞主线程,也就是我们这里的sleep 5000L。

顺便说下守护线程,在Java中有两类线程:User Thread(用户线程)、Daemon Thread(守护线程) 在Thanking in java 中说到:

守护线程也叫后台线程,是指在程序中运行的时候在后台提供一种通用服务的线程,并且这种并不属于程序中不可或缺的部分。因此,当所有的非后台线程结束时,程序也就终止了,同时会杀死进程中的所有后台线程。比较常用的是java GC。

猜你喜欢

转载自dragonhunter.iteye.com/blog/2288933