“This is the 7th day of my participation in the Gwen Challenge in November. Check out the details: The Last Gwen Challenge in 2021.”
Java monitors thread pools
ThreadPoolExecutor provides a set of methods for monitoring thread pools.
Int getActiveCount() gets the number of currently active threads in the thread pool.
Long getCompletedTaskCount() returns the number of tasks completed by the thread pool.
Int getCorePoolSize() Specifies the number of core threads in the thread pool.
Int getLargestPoolSize() returns the maximum number of threads that the thread pool has ever reached.
Int getMaximumPoolSize() returns the maximum capacity of the thread pool.
Int getPoolSize() Specifies the current thread pool size.
BlockingQueue getQueue() returns the BlockingQueue.
Long getTaskCount() returns the total number of tasks received by the thread pool.
package com.wkcto.threadpool; import java.util.concurrent.ArrayBlockingQueue; import java.util.concurrent.Executors; import java.util.concurrent.ThreadPoolExecutor; import java.util.concurrent.TimeUnit; Public class Test05 {public static void main(String[] args) throws InterruptedException {// Define the task first Runnable r = new Runnable() {@override public void run() {system.out.println (thread.currentThread ().getid () + "id "+ System.currentTimemillis ()); try { Thread.sleep(10000); } catch (InterruptedException e) {e.printStackTrace(); }}}; ThreadPoolExecutor poolExecutor = new ThreadPoolExecutor(2, 5, 0, timeunit.seconds, new ArrayBlockingQueue<>(5), Executors.defaultThreadFactory(), new ThreadPoolExecutor.DiscardPolicy()); For (int I = 0; i < 30; i++) { poolExecutor.submit(r); System.out.println(" Number of core threads in the current thread pool: " + poolExecutor.getCorePoolSize() + ", The maximum number of threads: "+ poolExecutor getMaximumPoolSize () +", the current thread pool size: "+ poolExecutor. GetPoolSize () +", the number of active threads: "+ PoolExecutor. GetActiveCount () + ", received the number of tasks: "+ poolExecutor. GetTaskCount () +", to complete the task: "+ poolExecutor. GetCompletedTaskCount () +", waiting for the number of jobs: "+ poolExecutor. GetQueue (). The size ()); TimeUnit.MILLISECONDS.sleep(500); } System.out.println("-----------------------------------------------"); While (poolExecutor. GetActiveCount () > = 0) {System. Out. Println (" the current thread pool core number of threads: " + poolExecutor.getCorePoolSize() + ", The maximum number of threads: "+ poolExecutor getMaximumPoolSize () +", the current thread pool size: "+ poolExecutor. GetPoolSize () +", the number of active threads: "+ PoolExecutor. GetActiveCount () + ", received the number of tasks: "+ poolExecutor. GetTaskCount () +", to complete the task: "+ poolExecutor. GetCompletedTaskCount () +", waiting for the number of jobs: "+ poolExecutor. GetQueue (). The size ()); Thread.sleep(1000); }}}Copy the code
Java thread pool extension
Sometimes you need to extend the thread pool, such as by monitoring the start and end times of each task, or by customizing some other enhanced functionality.
The ThreadPoolExecutor thread pool provides two methods:
● protected void afterExecute(Runnable r, Throwable t)
● protected void beforeExecute(Thread t, Runnable r)
The beforeExecute() method is called before a task is executed in the thread pool, and afterExecute() is executed after the task ends (the task exits unexpectedly).
ThreadPoolExecutor defines an internal Worker class. The Worker threads in the ThreadPoolExecutor thread pool are instances of the Worker class. Worker instances call beforeExecute() and afterExecute() methods during execution.
package com.wkcto.threadpool; import com.wkcto.produerstack.MyStack; import java.util.concurrent.ExecutorService; import java.util.concurrent.LinkedBlockingQueue; import java.util.concurrent.ThreadPoolExecutor; import java.util.concurrent.TimeUnit; Private static class MyTask implements Runnable{String name; private static class MyTask implements Runnable; public MyTask(String name) { this.name = name; } @override public void run() {system.out.println (name + thread.currentThread ().getid () + "execute "); try { Thread.sleep(1000); } catch (InterruptedException e) {e.printStackTrace(); }}} public static void main(String[] args) { You can define a thread pool class to inherit from ThreadPoolExecutor, overriding the beforeExecute()/afterExecute() method in a subclass, or you can directly use ThreadPoolExecutor's internal ExecutorService class executorService = new ThreadPoolExecutor(5, 5, 0, TimeUnit.SECONDS, New LinkedBlockingQueue<>()){Override protected void beforeExecute(Thread t, Runnable r) {system.out.println (t.getid () + "Thread ready to execute task:" + ((MyTask)r).name); } @override protected void afterExecute(Runnable r, Throwable t) {system.out.println (((MyTask)r).name + "afterExecute "); } @override protected void terminated() {system.out.println (" thread pool exit "); }}; For (int I = 0; i < 5; i++) { MyTask task = new MyTask("task-" + i); executorService.execute(task); Executorservice.shutdown (); // Closing the thread pool simply means that the thread pool is not receiving any new tasks, and the received tasks in the thread pool are executing normally}}Copy the code