线程池合理配置线程数

线程池合理配置线程数

大厂面试题:

1、请你谈谈对volatile的理解?

2、CAS你知道吗?

3、原子类AtomicInteger的ABA问题谈谈?原子更新引用知道吗?

4、我们都知道ArrayList是线程不安全的,请编码写一个不安全的案例并给出解决方案?

5、公平锁/非公平锁/可重入锁/递归锁/自旋锁谈谈你的理解?请手写一个自旋锁。

6、CountDownLatch、CyclicBarrier、Semaphore使用过吗?

7、阻塞队列知道吗?

8、线程池用过吗?ThreadPoolExecutor谈谈你的理解?

9、线程池用过吗?生产上你是如何设置合理参数?

10、死锁编码及定位分析?

 

1、线程池如何配置合理线程数

(1)CPU密集型

       CPU密集型的意思就是该任务需要大量运算,而没有阻塞,CPU一直全速运行。

       CPU密集型任务只有在真正的多核CPU上才可能得到加速(通过多线程)。

       CPU密集型任务配置尽可能少的线程数。

       CPU密集型线程数配置公式:CPU核数+1个线程的线程池

 

(2)IO密集型

       IO密集型,即该任务需要大量的IO,即大量的阻塞。

       在单线程上运行IO密集型任务会导致浪费大量的CPU运算能力浪费在等待。

       所以IO密集型任务中使用多线程可以大大的加速程序运行,即使在单核CPU上,这种加速主要利用了被浪费掉的阻塞时间。

      

       第一种配置方式:

       由于IO密集型任务线程并不是一直在执行任务,则应配置尽可能多的线程。

       配置公式:CPU核数 * 2。

       第二种配置方式:

       IO密集型时,大部分线程都阻塞,故需要多配置线程数。

       配置公式:CPU核数 / 1 – 阻塞系数(0.8~0.9之间)

       比如:8核 / (1 – 0.9) = 80个线程数

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值