本地写测试程序需要使用到多线程,就创建了一个线程池(参数没有深究,能保证测试程序运行就行),结果发现线程池并未按照预期创建多线程。
线程池相关代码如下:
测试代码如下:
运行结果如下,并未按照预期启动多线程,执行多个Runnable,而是阻塞在countDownLatch.await()的Runnable,而countDownRunnale并未执行:
查看了ThreadPoolExecutor的execute代码,发现使用线程池运行Runnable时,有三个分支:
1.如果核心线程都被占用(如第一个红框逻辑),走分支2
2.将Runnable加入到队列workQueue中(第二个红框),如果加入队列成功,不创建新的线程,等待已有线程运行。如果加入队列失败,走分支3
3.创建非核心线程去运行(第三个红框)