我利用线程池是为了分批的处理任务,开多线程来做事来省时,但又要等全都结束了,再给前端回话。
在此情境下,我利用线程池ThreadPoolExecutor 类对线程的监控机制,来实现。
首先要声明一个线程池
ThreadPoolExecutor executor = new ThreadPoolExecutor(5, 16, 200,
TimeUnit.MILLISECONDS, new ArrayBlockingQueue<Runnable>(5));
然后用内部类的写法声明了线程t
//朕要先写圣旨
final Thread t = new Thread(new Runnable() {
public void run() {
//圣旨内容
}
});
//紧急程度是10
t.setPriority(10);
//让太监去传圣旨,去干活
executor.execute(t);
//此代码块要放循环里或者手写多次,写一次的话我还用线程干嘛呀
最后利用线程池的属性来监控执行的线程
while (true) {
if (executor.getPoolSize() == executor.getCompletedTaskCount()) {
//线程池中线程数目 == 已执行完的任务数目
break;
}
}
//线程池就好比锦衣卫,朕直接问它就好了,当break出来时,说明是都干好了。洗洗睡了
主要思路:开始时走过弯路,还要想着弄个专门记录线程执行状态的表,然后去看那个表的情况来判断线程的执行情况。现在觉得很傻啊,我只要把线程管理起来放在池子里,盯着池子看就好了。
如有新的建议 和 存在的问题 欢迎叨扰。