阅读量:0
要查看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()
方法关闭线程池。