对于这个基础知识,做个记录:
首先还是复习下线程和进程的区别。
最主要的点就是:进程是资源分配的最小单位,线程是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) 有感!
可以参考 [Go MPG 模型之铺垫-常见的线程模型](https://blog.csdn.net/cpxsxn/article/details/108435869) 中提到的内核级线程模型: 每个线程可以独立被操作系统调度分配到 CPU 上执行指令,同时某个线程的阻塞并不会影响到进程内其他线程工作的执行。