为什么多线程可以利用到多核

对于这个基础知识,做个记录:

首先还是复习下线程和进程的区别。
    最主要的点就是:进程是资源分配的最小单位,线程是CPU调度的最小单位。(一个是相当于一个容器,一个是具体被CPU操作的)
    进程间资源不共享,而多个线程是共享同个进程分配的资源的。
  
由于线程分用户线程和内核线程。内核线程再调用的时候可以去不同的核心去操作。所以多线程是可以利用到多核的。
from: https://blog.51cto.com/jesnridy/2084498

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

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

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

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

下面一句话将惊醒梦中人:
现代os都将线程作为最小调度单位,进程作为资源分配的最小单位。 在windows中进程是不活动的,只是作为线程的容器。
也就是说,java中的所有线程确实在JVM进程中,但是CPU调度的是进程中的线程。
from: https://blog.csdn.net/maosijunzi/article/details/42527553?utm_medium=distribute.pc_relevant.none-task-blog-BlogCommendFromMachineLearnPai2-1.nonecase&depth_1-utm_source=distribute.pc_relevant.none-task-blog-BlogCommendFromMachineLearnPai2-1.nonecase

自己的理解:

一个进程里的多线程肯定可以跑在多核上,否则死锁从何而来,想想pthread_mutex_lock;
父子进程更是可以跑在多核上,因为有说父子进程谁先结束不一定。
由于全局变量在每个进程里都有一份拷贝,所以对多进程来说访问全局变量是不需要加锁控制的;线程是共享全局变量的,所以对多线程来说访问全局变量是需要加线程锁的。
读 [廖雪峰-Python-多线程](https://www.liaoxuefeng.com/wiki/897692888725344/923056337842176) 有感!
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章