java线程可以在运行在多个cpu核上吗?

我是一直都以为这个问题的答案是肯定的,也就是说可以运行在多核上。但是有一天见到这样的一个理论,我就顿时毁三观了。

JVM在操作系统中是作为一个进程的,java所有的线程都运行自这个JVM进程中,所以说java线程某个时间只可能运行在一个核上。

这个说法对我的打击太大了,我不能接受。于是就开始多方求证。网上搜索 和朋友一起讨论,最终证实了java线程是可以运行在多核上的,为什么呢?

下面一句话将惊醒梦中人:

现代os都将线程作为最小调度单位,进程作为资源分配的最小单位。 在windows中进程是不活动的,只是作为线程的容器。

也就是说,java中的所有线程确实在JVM进程中,但是CPU调度的是进程中的线程。

生命太过短暂,今天放弃了明天不一定能得到

java线程可以在运行在多个cpu核上吗?

相关文章:

你感兴趣的文章:

标签云: