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

20 篇文章 0 订阅
13 篇文章 0 订阅

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

首先还是复习下线程和进程的区别。
    最主要的点就是:进程是资源分配的最小单位,线程是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 上执行指令,同时某个线程的阻塞并不会影响到进程内其他线程工作的执行。
  • 4
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值