我正在使用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
这个答案假设你正在寻找一个“尚未完成”的计数.你的问题与自己相矛盾,所以我不完全确定你在问什么.如果这不正确,请回复我对您的问题的评论,我会相应地更新此答案.
原文地址:https://www.jb51.cc/java/127979.html
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。