加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > Java > 正文

java – 使用ThreadPoolExecutor的活动任务数

发布时间:2020-12-15 02:50:51 所属栏目:Java 来源:网络整理
导读:我正在使用ThreadPoolExecutor在我的 Java应用程序中执行任务.我有一个要求,我想在执行程序队列中的任何时间点获取队列中的活动任务数.我查看了 javadoc的ThreadPoolExecutor并找到了两个相关的方法:getTaskCount()和getCompletedTaskCount(). 根据文档,我
我正在使用ThreadPoolExecutor在我的 Java应用程序中执行任务.我有一个要求,我想在执行程序队列中的任何时间点获取队列中的活动任务数.我查看了 javadoc的ThreadPoolExecutor并找到了两个相关的方法:getTaskCount()和getCompletedTaskCount().

根据文档,我可以分别从上述两种方法中获得计划任务和已完成任务的数量.但我无法找到在任何时间点获取队列中活动任务数量的解决方案.我可以这样做:

getTaskCount() = getCompletedTaskCount() + failed tasks + active tasks

但是,无法直接获得失败任务的数量以达到预期的计算.

我在这里错过了什么吗?

解决方法

我不认为您需要通过您尝试使用的计算来了解失败的计数.
long submitted = executor.getTaskCount();
long completed = executor.getCompletedTaskCount();
long notCompleted = submitted - completed; // approximate

会(大约)足够.

或者,您可以使用getQueue()size()

int queued = executor.getQueue().size();
int active = executor.getActiveCount();
int notCompleted = queued + active; // approximate

这个答案假设你正在寻找一个“尚未完成”的计数.你的问题与自己相矛盾,所以我不完全确定你在问什么.如果这不正确,请回复我对您的问题的评论,我会相应地更新此答案.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读