获取线程池中任务执行数量

本文通过实例展示了如何利用Java的ThreadPoolExecutor来获取线程池的任务执行状态,包括当前排队线程数、活动线程数、已完成任务数以及总线程数,并展示了这些信息随时间的变化情况,帮助理解线程池的工作机制。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

通过线程池进行任务处理,有时我们需要知道线程池中任务的执行状态。

通过ThreadPoolExecutor的相关API实时获取线程数量,排队任务数量,执行完成线程数量等信息。

实例

private static ExecutorService es = new ThreadPoolExecutor(50, 100, 0L, TimeUnit.MILLISECONDS,
new LinkedBlockingQueue<Runnable>(
100000
));
 
public static void main(String[] args) throws Exception
 {
for (int i = 0; i < 100000; i++) {
    es.execute(() -> {
        System.out.print(1);
        try{
    Thread.sleep(1000);
        } 
        catch(InterruptedException e) {
                e.printStackTrace();
            }
        });
 
    }
 
ThreadPoolExecutor tpe = ((ThreadPoolExecutor) es);
while (true) {
    System.out.println();
    int queueSize = tpe.getQueue().size();
    System.out.println("当前排队线程数:"+ queueSize);
 
    int activeCount = tpe.getActiveCount();
    System.out.println("当前活动线程数:"+ activeCount);
    
    long completedTaskCount = tpe.getCompletedTaskCount();
    System.out.println("执行完成线程数:"+ completedTaskCount);
    
    long taskCount = tpe.getTaskCount();
    System.out.println("总线程数:"+ taskCount);
 
    Thread.sleep(3000);
    }
}

比如我们每隔3秒获取一次执行状态信息,总共有50个工作线程。

第一次输出:


当前排队线程数:
99950
 
当前活动线程数:
50
 
执行完成线程数:
0
 
总线程数(排队线程数 + 活动线程数 +  执行完成线程数):
100000

第二次输出:


当前排队线程数:
99800
 
当前活动线程数:
50
 
执行完成线程数:
150
 
总线程数(排队线程数 + 活动线程数 +  执行完成线程数):
100000

说明通过API可以获取不断变化的线程及线程任务数量了。

转载于:https://blog.csdn.net/weixin_34160277/article/details/92073367

### 查询Java线程池中的当前活动线程数量 为了查询Java线程池内的当前活动线程数量,可以通过`ThreadPoolExecutor`类提供的方法实现。具体来说,`getActiveCount()`方法能够返回当前正活跃的工作线程数目[^4]。 下面是一个简单的例子展示如何获取这些信息: ```java import java.util.concurrent.*; public class ThreadPoolExample { public static void main(String[] args) throws InterruptedException { // 创建一个固定大小的核心线程数为3的线程池 ThreadPoolExecutor executor = (ThreadPoolExecutor) Executors.newFixedThreadPool(3); // 提交多个任务到线程池中执行 for(int i = 0; i < 10; ++i){ final int taskID = i; executor.submit(() -> { System.out.println("Task " + taskID + " is running"); try { Thread.sleep((long)(Math.random()*100)); } catch(Exception e){} System.out.println("Task " + taskID + " has finished"); }); // 打印当前活动线程的数量 System.out.printf("Current active threads: %d\n", executor.getActiveCount()); } // 关闭线程池 executor.shutdown(); executor.awaitTermination(Long.MAX_VALUE, TimeUnit.NANOSECONDS); } } ``` 此程序创建了一个具有三个核心线程的线程池,并向其中提交了十个简单打印消息的任务。每次提交新任务之后都会调用`getActiveCount()`来显示此时有多少个线程处于忙碌状态。 值得注意的是,在实际应用环境中,如果想要更精细地控制或监控线程池的行为,则可能还需要考虑其他因素如最大允许的最大线程数、队列长度以及拒绝策略等配置项。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值