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。