java线程数的设置和cpu关系

cpu采用分片机制执行线程,给每个线程划分很小的时间颗粒去执行,但是真正的项目中,一个程序要做很多的操作,读写磁盘、数据逻辑处理,处于业务需求必要的休眠等等操作,当程序在进行I/O操作的时候,线程是阻塞的,线程由运行状态切换到等待状态,此时cpu会做上下文切换,以便处理其他的程序;当I/O操作完成后,cpu出收到一个来自硬盘的中断信号,并进入中断处理例程,手头正在执行的线程因此被打断,回到ready对列。而先前因I/O而waiting的线程随着I/O的完成也再次回到就绪队列,这时cpu可能会选择它来执行。
如果所有的任务都是计算密集型的,则创建的多线程数=处理器核心说就可以了,如果io操作比较耗时,则根据具体情况调整线程数,此时 多线程数=n*处理器核心数 一般情况程序线程数等于cpu线程数的两到三倍就能很好的利用cpu了,过多的程序线程数不但不会提高性能,反而还会因为线程间的频繁切换而受影响,具体需要根据线程处理的业务考虑,不断调整 线程数个数,确定当前系统最优的线程数。

你可能感兴趣的:(java线程数的设置和cpu关系)