ThreadPoolExecutor的corePoolSize、maximumPoolSize和poolSize

看两段源码:

  1 public ThreadPoolExecutor(int corePoolSize,
  2 
  3         int maximumPoolSize,
  4 
  5         long keepAliveTime,
  6 
  7         TimeUnit unit,
  8 
  9         BlockingQueue<Runnable> workQueue,
 10 
 11         ThreadFactory threadFactory,
 12 
 13         RejectedExecutionHandler handler) {
 14 
 15         if (corePoolSize < 0 ||
 16 
 17         maximumPoolSize <= 0 ||
 18 
 19         maximumPoolSize < corePoolSize ||
 20 
 21         keepAliveTime < 0)
 22 
 23         throw new IllegalArgumentException();
 24 
 25         if (workQueue == null || threadFactory == null || handler == null)
 26 
 27         throw new NullPointerException();
 28 
 29         this.acc = System.getSecurityManager() == null ?
 30 
 31         null :
 32 
 33         AccessController.getContext();
 34 
 35         this.corePoolSize = corePoolSize;
 36 
 37         this.maximumPoolSize = maximumPoolSize;
 38 
 39         this.workQueue = workQueue;
 40 
 41         this.keepAliveTime = unit.toNanos(keepAliveTime);
 42 
 43         this.threadFactory = threadFactory;
 44 
 45         this.handler = handler;
 46 
 47         }
 48 
 49 private boolean addWorker(Runnable firstTask, boolean core) {
 50 
 51         retry:
 52 
 53         for (;;) {
 54 
 55         int c = ctl.get();
 56 
 57         int rs = runStateOf(c);
 58 
 59     // Check if queue empty only if necessary.
 60 
 61         if (rs >= SHUTDOWN &&
 62 
 63         ! (rs == SHUTDOWN &&
 64 
 65         firstTask == null &&
 66 
 67         ! workQueue.isEmpty()))
 68 
 69         return false;
 70 
 71         for (;;) {
 72 
 73         int wc = workerCountOf(c);
 74 
 75         if (wc >= CAPACITY ||
 76 
 77         wc >= (core ? corePoolSize : maximumPoolSize))
 78 
 79         return false;
 80 
 81         if (compareAndIncrementWorkerCount(c))
 82 
 83         break retry;
 84 
 85         c = ctl.get(); // Re-read ctl
 86 
 87         if (runStateOf(c) != rs)
 88 
 89         continue retry;
 90 
 91     // else CAS failed due to workerCount change; retry inner loop
 92 
 93         }
 94 
 95         }
 96 
 97         boolean workerStarted = false;
 98 
 99         boolean workerAdded = false;
100 
101         Worker w = null;
102 
103         try {
104 
105         w = new Worker(firstTask);
106 
107     final Thread t = w.thread;
108 
109         if (t != null) {
110 
111     final ReentrantLock mainLock = this.mainLock;
112 
113         mainLock.lock();
114 
115         try {
116 
117 // Recheck while holding lock.
118 
119 // Back out on ThreadFactory failure or if
120 
121 // shut down before lock acquired.
122 
123         int rs = runStateOf(ctl.get());
124 
125         if (rs < SHUTDOWN ||
126 
127         (rs == SHUTDOWN && firstTask == null)) {
128 
129         if (t.isAlive()) // precheck that t is startable
130 
131         throw new IllegalThreadStateException();
132 
133         workers.add(w);
134 
135         int s = workers.size();
136 
137         if (s > largestPoolSize)
138 
139         largestPoolSize = s;
140 
141         workerAdded = true;
142 
143         }
144 
145         } finally {
146 
147         mainLock.unlock();
148 
149         }
150 
151         if (workerAdded) {
152 
153         t.start();
154 
155         workerStarted = true;
156 
157         }
158 
159         }
160 
161         } finally {
162 
163         if (! workerStarted)
164 
165         addWorkerFailed(w);
166 
167         }
168 
169         return workerStarted;
170 
171         }

 

以上可以看出,ThreadPoolExecutor的主要参数有:corePoolSize , maximumPoolSize , keepAliveTime ,workQueue,threadFactory,handler ,对于几个参数,我们该如何理解呢?

先看看这几个参数:

corePoolSize :

顾名思义,核心线程大小,即在没有任务需要执行的时候线程池的大小,并且只有在工作队列满了的情况下才会创建超出这个数量的线程;

maximuxPoolSize :

线程池中允许创建的最大线程数大小;

poolSize :

当前线程池中线程的数量,当改值为0的时候,意味着没有任何线程,线程池会终止;同时,poolSize不会超过maximumPoolSize;

看看官方解释:

Queuing

Any BlockingQueue may be used to transfer and hold submitted tasks. The use of this queue interacts with pool sizing:

● If fewer than corePoolSize threads are running, the Executor always prefers adding a new thread rather than queuing.

● If corePoolSize or more threads are running, the Executor always prefers queuing a request rather than adding a new thread.

● If a request cannot be queued, a new thread is created unless this would exceed maximumPoolSize, in which case, the task will be rejected.

理解:

1、如果当前线程池的线程数还没有达到核心线程数大小,即 poolSize < corePoolSize ,无论是否有空闲的线程,系统回新增一个线程来处理新提交的任务;

2、如果当前线程池的线程数大于或者等于核心线程数大小,即 poolSize >= corePoolSize,且任务队列未满时,将提交的任务提交到阻塞队列中,等待处理workQueue.offer(command);

3、如果当前线程池的线程数大于或者等于核心线程数大小,即 poolSize >= corePoolSize,且任务队列已满时,分以下两种情况:

3.1、poolSize < maximumPoolSize ,新增线程来处理任务;

3.2、poolSize = maximuxPoolSize ,意味中线程池的处理能力已经达到极限,此时会拒绝增加新的任务,至于如何拒绝,取决于RejectedExecutionHandler

posted @ 2019-08-09 11:00  想念泡凤爪的味道  阅读(792)  评论(0编辑  收藏  举报