创建线程池有个CorePoolSize参数,指的是核心线程数,该参数应该设置为多大呢?
CPU密集型
一般公式:CPU核数 + 1
通过以下代码动态获取CPU核数:
Runtime.getRuntime().availableProcessors()
IO密集型
(1)配置方式一
IO密集型任务线程并不是一直在执行任务,则应该配置尽可能多的线程
例如:CPU核数 * 2
(2)配置方式二
CPU核数 / (1 - 阻塞系数),阻塞系数在0.8~0.9之间
两种方式并没有绝对的最优,实际生产环境应该结合压力测试进行调整