社区
Linux_Kernel
帖子详情
在多核CPU下,同一进程下的多个线程可以并行运行吗?
不辣
2008-10-16 05:30:12
在多核CPU下,同一进程下的多个线程可不可以并行运行,是不是一个进程下的所有线程都在同一个cpu上运行?
...全文
5642
11
打赏
收藏
举报
写回复
11 条
回复
切换为时间正序
当前发帖距今超过3年,不再开放新的回复
发表回复
dog250
2008-10-17
如果是内核线程(就是fork出来的,pthread_create在2.4后最终也用fork,具体参看其实现),那么可以调度到多cpu,内核支持线程的诱导因素之一就是可以利用多cpu资源进行并行计算;如果是用户线程,那么就不能在多cpu上并行计算了,用户库线程的弊端之一就是不能利用多cpu资源;具体到调度,就是当内核发现本cpu没有任何可运行线程时,就会去别的忙cpu上拽几个下来,当然这是内核自发进行的多cpu调度,作为用户也可以自觉地将线程邦定到具体cpu,更加确定的利用多cpu,当然什么都不是任其发展的,内核不能随便从哪个忙cpu上拽线程,还要看线程愿不愿意(参见linux内核函数cpuset_cpus_allowed),另外还要考虑smt(在intel平台即超线程)的兄弟cpu,还要考虑numa,你总不能让本地cpu的线程跑到遥远的cpu上运行吧.....(还有很多好玩的,自己看代码吧)
以上扯的都是linux的实现,是我对代码的总结,感兴趣可自行阅读。至于windows平台,道道就更多了(windows的道道总是能把你搞晕,不过玩玩挺好,挺有趣,比如动态优先级提升之类的),它甚至可以让内核线程运行在一个专门cpu上,别的用户线程分享别的cpu(linux也可以做到,但是有意思吗?).....
希望能解决lz的问题,如有不明:qq:23870617。本人专注操作系统,呵呵,愿结志同道合之士
打赏
举报
回复
3
once_and_again
2008-10-17
study....
打赏
举报
回复
赞
不辣
2008-10-17
不错,学习了
看得出这位仁兄对linux的底层代码还是有一番研究的,不过,你留的QQ似乎加不上,要回答问题的
打赏
举报
回复
赞
once_and_again
2008-10-17
不可以吧,因为共享进程的一些资源,
怎么处理,不成了异步了吗?
打赏
举报
回复
赞
快乐田伯光
2008-10-17
我以前的理解有问题!
这么说的话能否运行在同一CPU的不同核上,就看这个执行实体能不能被内核所看到,这样的话,不管是2.4前的LinuxThread实现还是后来的NPTL实现,多线程都可以在不同的核上同时运行。除非是那种完全的用户态线程实现,才不会在不同的核上运行。
打赏
举报
回复
赞
mingbao
2008-10-17
还有,创建线程的时候,可以指定该线程绑定到哪个CPU上。
打赏
举报
回复
赞
mingbao
2008-10-17
Linux SMP结构既可以在多个CPU上并行运行多个进程,也可以在多个CPU上并行运行同一进程的多个线程。
对于运行在多CPU上的LINUX来说,每个CPU有一个自己的调度队列。当多个调度队列中的进程数相差超过一定的数值时,内核会自动进行调整,从而使得各CPU上的进程数保持均衡。
另外需要说明的是,Linux下的线程,相当于进程,因为它在内核中有自己的task_struct。其实线程与进程的唯一差别是,线程没有自己独立的虚存空间。
也就是说,如果一个进程创建了一个线程,那么新线程与老的主线程,就相当于两个共享虚存空间的进程。内核的调度程序是以task_struct为单位进行调度的。
打赏
举报
回复
赞
快乐田伯光
2008-10-17
不管是2.4前还是后都不是直接fork,都是用clone()调用,fork()也调用clone(),只是2.4前后clone()添加了新的参数来放便线程的实现。
另外,并不能同时在多个CPU运行不同的进程,只能在多个CPU上运行同一个进程的不同线程吧。
打赏
举报
回复
赞
realdragon2
2008-10-16
Linux 以前的内核版本并没有提供对线程的支持, 在内核中是用轻量级进程来支持线程的, 这是不符合POSIX标准的.
但在2.4以后的内核实现中, 提供了对线程的支持, 也就是内核开发者重写了内核的线程库. 具体,可以Google一下: Linux NPTL.
打赏
举报
回复
赞
xlanchen
2008-10-16
[Quote=引用 1 楼 guosha 的回复:]
现在同一进程下的多个线程是可以在多核CPU下并行运行的。但2.4内核及以前的系统实现的线程没有内核支持,无法在多核的情况下并行运行。
[/Quote]
多线程的概念主要有两种:一种是用户态多线程;一种是内核态多线程
内核态多线程,如楼上所言,在操作系统内核的支持下可以在多核下并行运行;
对于用户态多线程,尽管没有内核的直接支持,但若一个用户态线程对应于内核的一个进程的话(从这个角度,内核还是间接支持的),仍然是可以在多核上并行运行的。
因此,这归结为,用户态多线程的实现技术。
似乎目前Linux上的用户态多线程,就是利用了内核的进程来实现的。
打赏
举报
回复
赞
快乐田伯光
2008-10-16
现在同一进程下的多个线程是可以在多核CPU下并行运行的。但2.4内核及以前的系统实现的线程没有内核支持,无法在多核的情况下并行运行。
打赏
举报
回复
赞
相关推荐
同一
进程
的
多
个
线程
可以
被
多
个
CPU
核
心
并行
执行
吗
?
一个
进程
中
的
多
个
线程
可以
被
多
个
处理器
并行
执行。
线程
VS
进程
,
多
线程
VS
多
进程
,
并行
VS并发,单
核
cpu
VS
多
核
cpu
概论 程序是为完成特定任务、用某种语言编写
的
组指令
的
集合。即指一段静态
的
代码
,
静态...若一个
进程
同一
时间
并行
执行
多
个
线程
,
就是支持
多
线程
的
线程
作为调度和执行
的
单位
,
每个
线程
拥有独立
的
运行
栈和程序计数器...
多
CPU
和
多
核
CPU
对应
多
进程
和
多
线程
调度
进程
和
线程
在
多
核
cpu
,
多
cpu
中
的
运行
关系
cpu
架构和工作原理 计算机有5大基本组成部分
,
运算器
,
控制器
,
存储器
,
输入和输出。运算器和控制器封装到一起
,
加上寄存器组和
cpu
内部总线构成中央处理器(
CPU
)。
cpu
...
多
核
、
多
线程
、并发与
并行
一个
进程
可以
包含一个
线程
(单
线程
的
进程
)
,
也
可以
包含
多
个
线程
(
多
线程
的
进程
)。
多
核
与
多
线程
在
单
核
时代
,
也
可以
实现
多
线程
,
同一
时间内
,
各个(
同一
或者不同)
线程
争夺
CPU
时间片。
在
多
核
时代
,
各个
进程
及其...
并发
,
并行
,
多
CPU
,
多
核
,
多
进程
,
多
线程
在
并发程序中
可以
同时拥有两个或者
多
个
线程
。这意味着
,
如果程序
在
单
核
处理器上
运行
,
那么这两个
线程
将交替地换入或者换出内存。这些
线程
是同时“存
在
”
的
——每个
线程
都处于执行过程中
的
某个状态。
发帖
Linux_Kernel
微信扫一扫
点击复制链接
分享社区
4314
社区成员
1.7w+
社区内容
Linux/Unix社区 内核源代码研究区
社区管理员
加入社区
帖子事件
创建了帖子
2008-10-16 05:30
社区公告
暂无公告