import java.util.concurrent.ArrayBlockingQueue;
import java.util.concurrent.LinkedBlockingQueue;
import java.util.concurrent.RejectedExecutionHandler;
import java.util.concurrent.ThreadPoolExecutor;
import java.util.concurrent.TimeUnit;
import java.util.concurrent.atomic.AtomicInteger;
public class Tests {
private static final AtomicInteger COUNTER = new AtomicInteger(1);
private static final AtomicInteger THREAD_EXPAND = new AtomicInteger(1);
// 阻塞队列一旦满了会抛出异常
private static final LinkedBlockingQueue QUEUE = new LinkedBlockingQueue(30);
public static void main(String[] args) {
int corePoolSize = 4;
int maximumPoolSize = 10;
// 线程池第二个参数是线程组大数量
// 只有在WORK QUEUE满了之后才会扩容
// 如果WORK QUEUE满进行过扩容之后依旧有任务追加则会执行RejectedExecutionHandler策略
ThreadPoolExecutor executor = new ThreadPoolExecutor(corePoolSize, maximumPoolSize, 1000L, TimeUnit.MILLISECONDS, QUEUE, new RejectedExecutionHandler() {
@Override
public void rejectedExecution(Runnable r, ThreadPoolExecutor executor) {
System.out.println("rejectedExecution $: 此处队列大小:" + QUEUE.size() + " 此时ActiveCount: " + executor.getActiveCount() + " 拒绝次数: " + COUNTER.getAndIncrement());
}
});
for (int i = 1; i <= 50; i++) {
executor.submit(new Runnable() {
@Override
public void run() {
try {
Thread.sleep(1000000);
} catch (InterruptedException e) {
e.printStackTrace();
}
}
});
System.out.println("当前任务id :" + i + " => 此时ActiveCount:" + executor.getActiveCount());
if (executor.getActiveCount() > corePoolSize && executor.getActiveCount() < maximumPoolSize) {
System.out.println("线程池进行扩容:" + THREAD_EXPAND.getAndIncrement() + " 共计活跃线程数:" + executor.getActiveCount());
}
}
}
}
// output:
// 当前任务id :1 => 此时ActiveCount:1
// 当前任务id :2 => 此时ActiveCount:2
// 当前任务id :3 => 此时ActiveCount:3
// 当前任务id :4 => 此时ActiveCount:4
// 当前任务id :5 => 此时ActiveCount:4
// 当前任务id :6 => 此时ActiveCount:4
// 当前任务id :7 => 此时ActiveCount:4
// 当前任务id :8 => 此时ActiveCount:4
// 当前任务id :9 => 此时ActiveCount:4
// 当前任务id :10 => 此时ActiveCount:4
// 当前任务id :11 => 此时ActiveCount:4
// 当前任务id :12 => 此时ActiveCount:4
// 当前任务id :13 => 此时ActiveCount:4
// 当前任务id :14 => 此时ActiveCount:4
// 当前任务id :15 => 此时ActiveCount:4
// 当前任务id :16 => 此时ActiveCount:4
// 当前任务id :17 => 此时ActiveCount:4
// 当前任务id :18 => 此时ActiveCount:4
// 当前任务id :19 => 此时ActiveCount:4
// 当前任务id :20 => 此时ActiveCount:4
// 当前任务id :21 => 此时ActiveCount:4
// 当前任务id :22 => 此时ActiveCount:4
// 当前任务id :23 => 此时ActiveCount:4
// 当前任务id :24 => 此时ActiveCount:4
// 当前任务id :25 => 此时ActiveCount:4
// 当前任务id :26 => 此时ActiveCount:4
// 当前任务id :27 => 此时ActiveCount:4
// 当前任务id :28 => 此时ActiveCount:4
// 当前任务id :29 => 此时ActiveCount:4
// 当前任务id :30 => 此时ActiveCount:4
// 当前任务id :31 => 此时ActiveCount:4
// 当前任务id :32 => 此时ActiveCount:4
// 当前任务id :33 => 此时ActiveCount:4
// 当前任务id :34 => 此时ActiveCount:4
// 当前任务id :35 => 此时ActiveCount:5
// 线程池进行扩容:1 共计活跃线程数:5
// 当前任务id :36 => 此时ActiveCount:6
// 线程池进行扩容:2 共计活跃线程数:6
// 当前任务id :37 => 此时ActiveCount:7
// 线程池进行扩容:3 共计活跃线程数:7
// 当前任务id :38 => 此时ActiveCount:8
// 线程池进行扩容:4 共计活跃线程数:8
// 当前任务id :39 => 此时ActiveCount:9
// 线程池进行扩容:5 共计活跃线程数:9
// 当前任务id :40 => 此时ActiveCount:10
// rejectedExecution $: 此处队列大小:30 此时ActiveCount: 10 拒绝次数: 1
// 当前任务id :41 => 此时ActiveCount:10
// rejectedExecution $: 此处队列大小:30 此时ActiveCount: 10 拒绝次数: 2
// 当前任务id :42 => 此时ActiveCount:10
// rejectedExecution $: 此处队列大小:30 此时ActiveCount: 10 拒绝次数: 3
// 当前任务id :43 => 此时ActiveCount:10
// rejectedExecution $: 此处队列大小:30 此时ActiveCount: 10 拒绝次数: 4
// 当前任务id :44 => 此时ActiveCount:10
// rejectedExecution $: 此处队列大小:30 此时ActiveCount: 10 拒绝次数: 5
// 当前任务id :45 => 此时ActiveCount:10
// rejectedExecution $: 此处队列大小:30 此时ActiveCount: 10 拒绝次数: 6
// 当前任务id :46 => 此时ActiveCount:10
// rejectedExecution $: 此处队列大小:30 此时ActiveCount: 10 拒绝次数: 7
// 当前任务id :47 => 此时ActiveCount:10
// rejectedExecution $: 此处队列大小:30 此时ActiveCount: 10 拒绝次数: 8
// 当前任务id :48 => 此时ActiveCount:10
// rejectedExecution $: 此处队列大小:30 此时ActiveCount: 10 拒绝次数: 9
// 当前任务id :49 => 此时ActiveCount:10
// rejectedExecution $: 此处队列大小:30 此时ActiveCount: 10 拒绝次数: 10
// 当前任务id :50 => 此时ActiveCount:10