要查看Java线程池的状态,我们可以使用ThreadPoolExecutor
类的一些方法。以下是一些常用的方法:
getPoolSize()
:获取当前线程池中的线程数。getActiveCount()
:获取正在执行任务的线程数。getCompletedTaskCount()
:获取已完成的任务数。getTaskCount()
:获取提交给线程池的总任务数。isShutdown()
:判断线程池是否已经关闭。isTerminated()
:判断线程池是否已经终止。另外,你还可以使用java.util.concurrent.ThreadPoolExecutor
类的toString()
方法来打印线程池的一些详细信息,例如线程池的当前状态、核心线程数、最大线程数、工作队列大小等。
以下是一个示例代码,演示了如何查看线程池的状态:
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
public class ThreadPoolStatusExample {
public static void main(String[] args) {
ExecutorService executorService = Executors.newFixedThreadPool(5);
// 提交一些任务给线程池
for (int i = 0; i < 10; i++) {
executorService.execute(() -> {
try {
Thread.sleep(1000);
System.out.println("Task executed by thread: " + Thread.currentThread().getName());
} catch (InterruptedException e) {
e.printStackTrace();
}
});
}
// 输出线程池的状态
System.out.println("Pool Size: " + ((ThreadPoolExecutor) executorService).getPoolSize());
System.out.println("Active Count: " + ((ThreadPoolExecutor) executorService).getActiveCount());
System.out.println("Completed Task Count: " + ((ThreadPoolExecutor) executorService).getCompletedTaskCount());
System.out.println("Task Count: " + ((ThreadPoolExecutor) executorService).getTaskCount());
System.out.println("Is Shut Down: " + ((ThreadPoolExecutor) executorService).isShutdown());
System.out.println("Is Terminated: " + ((ThreadPoolExecutor) executorService).isTerminated());
// 关闭线程池
executorService.shutdown();
}
}
以上代码创建了一个固定线程数为5的线程池,提交了10个任务给线程池。然后通过强制转换为ThreadPoolExecutor
类型,使用相关方法获取线程池的状态信息。最后,调用shutdown()
方法关闭线程池。