java线程池如何合理的设置大小

线程池究竟设置多大要看你的线程池执行的什么任务了,CPU密集型、IO密集型、混合型,任务类型不一样,设置的方式也不同多线程

任务通常分为:CPU密集型、IO密集型、混合型,对于不一样类型的任务须要分配不一样大小的线程池线程

一、CPU密集型线程池

尽可能使用较小的线程池,通常Cpu核心数+1方法

由于CPU密集型任务CPU的使用率很高,若开过多的线程,只能增长线程上下文的切换次数,带来额外的开销cpu

二、IO密集型di

方法一:可使用较大的线程池,通常CPU核心数 * 2时间

IO密集型CPU使用率不高,可让CPU等待IO的时候处理别的任务,充分利用cpu时间

方法二:线程等待时间所占比例越高,须要越多线程。线程CPU时间所占比例越高,须要越少线程。
下面举个例子:
好比平均每一个线程CPU运行时间为0.5s,而线程等待时间(非CPU运行时间,好比IO)为1.5s,CPU核心数为8,那么根据上面这个公式估算获得:((0.5+1.5)/0.5)*8=32。这个公式进一步转化为:
最佳线程数目 = (线程等待时间与线程CPU时间之比 + 1)* CPU数目
三、混合型

能够将任务分为CPU密集型和IO密集型,而后分别使用不一样的线程池去处理,按状况而定

相关文章
相关标签/搜索