概述
Java的几种线程池都没有所有任务完成时的回调方法,也难以获取任务完成的数量;
而很多时候我们都需要在所有任务完成时进行下一步操作;
所以在此我提供一种简便的方法:
首先线程池可以往里面提交任务,我们就利用这个特点 将通知的任务接口放到最后,
那么如果执行此任务是就代表任务已经差不多完了,那么就使用handler发送通知,然后处理后续工作;
例如:
ExecutorService es = Executors.newFixedThreadPool(1);
//每次执行必须new一个线程池
es = Executors.newFixedThreadPool(1);
//添加所有任务
for (File file:fileslists){
filePacks.add(new FilePack(file));
}
//添加任务完成时的消息任务,该任务是最后一个执行的
es.submit(new Runnable() {
@Override
public void run() {
handler.sendMessage(Message.obtain());
}
});
//所有任务提交完成后,关闭添加任务功能;
es.shutdown();
最后
以上就是威武滑板为你收集整理的Java线程池获取全部完成时的状态并执行后续工作的全部内容,希望文章能够帮你解决Java线程池获取全部完成时的状态并执行后续工作所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复