当前位置:  技术问答>linux和unix

Linux中,物理CPU的分配是基于线程还是进程?

    来源: 互联网  发布时间:2015-10-24

    本文导语:  WINDOWS中CPU的分配基于线程, 所以多线程能支持多CPU, 今天看了老美的UNIX编程,指出UNIX中物理CPU分配是基于进程, 各线程只能在进程内部重新分配CPU资源,或者影射为系统线程才能参与全局CPU资源的竞争。 也就是...

WINDOWS中CPU的分配基于线程,
所以多线程能支持多CPU,
今天看了老美的UNIX编程,指出UNIX中物理CPU分配是基于进程,
各线程只能在进程内部重新分配CPU资源,或者影射为系统线程才能参与全局CPU资源的竞争。

也就是说,不管一个进程内有多少个用户线程,LINUX核心最多只能分配一个CPU给该进程,
除非将用户线程影射为SYSTEM线程?
是否如此?

难道只能FORK才能利用多CPU?汗啊

|
在Linux 2.2内核中,进程是通过系统调用fork创建的,
新的进程是原来进程的子进程,在Linux 2.2.x中,不存
在真正意义上的线程,Linux中常用的线程Pthread实际
上是通过进程来模拟的。

Linux 2.4内核允许在系统运行中动态调整进程数上限,
进程数只受制于物理内存的多少。

Linux 2.6内核,对进程调度经过重新编写,去掉了以前
版本中效率不高的算法。进程标识号(PID)的数目也从
3.2万升到10亿。内核内部的大改变之一就是Linux的线程
框架被重写,以使NPTL可以运行其上。

目前线程有用户态线程和核心态线程两种方法实现。
核心态线程的实现方法允许不同进程中的线程按照同一相
对优先调度方法进行调度,目前,线程主要的实现方法是
用户态线程,也就是同一进程的线程之间竞争CPU。
但也可以将某个线程固定的"绑"在一个轻进程之上。被绑定
的线程具有较高的响应速度,这是因为CPU时间片的调度是
面向轻进程的,绑定的线程可以保证在需要的时候它总有一
个轻进程可用。通过设置被绑定的轻进程的优先级和调度级
可以使得绑定的线程满足诸如实时反应之类的要求。
  设置线程绑定状态的函数为pthread_attr_setscope,
它有两个参数,第一个是指向属性结构的指针,第二个是绑定
类型,它有两个取值: PTHREAD_SCOPE_SYSTEM(绑定的)和
PTHREAD_SCOPE_PROCESS(非绑定的)。下面的代码即创建了
一个绑定的线程。

#include 
pthread_attr_t attr;
pthread_t tid;

/*初始化属性值,均设为默认值*/
pthread_attr_init(&attr);
pthread_attr_setscope(&attr, PTHREAD_SCOPE_SYSTEM);

pthread_create(&tid, &attr, (void *) my_function, NULL);


参考链接:
http://tech.ccidnet.com/art/308/20050912/330269_1.html
http://linux.chinaunix.net/doc/program/2001-08-11/642.shtml


|
物理cpu的分配应该都是基于进程的吧,关键是线程太多了。

|
在windows中,process只是作为资源分配的单位,调度的单位是thread,你开多thread总是好的
linux就不清楚了,似乎是用进程模拟的线程:(

|
我们可以把CPU资源看做不可重用的独占性资源,由线程取得,线程是资源的使用者.

    
 
 

您可能感兴趣的文章:

  • Windows和Linux下C++类成员方法作为线程函数方法介绍
  • 请问Linux核心支持多线程吗?开发库有线程库吗?线程好用吗?(稳定?)
  • Linux下GCC内置原子操作函数(多线程资源访问)介绍
  • 求个linux多线程编程的例子,要有线程池的 通用些更好
  • 请问Linux下线程开销为什么这么大?一个线程要占用近10M内存
  • Linux多线程时一些线程分不到时间片
  • 说说windows线程和linux线程的区别?
  • linux 下多线程 每个线程能否使用alarm来处理,信号是否会乱呢?
  • linux下,如何在多线程中每个线程设置一个定时器,在线等,急。。。谢谢
  • 在创建linux线程时为什么会多一个线程?
  • linux如何主动将线程放入到线程调度队列中重新排队?
  • 在linux RH73下为什么单进程只能开1021个线程线程.
  • Linux下如何让主线程挂起一个指定的时间段而子线程继续运行?谢谢
  • LINUX下有没有线程概念,和WIN下线程概念有什么不同,谢谢.
  • linux线程编程问题
  • linux线程最大数,奇怪,怎么只有300?而且线程是用完就没了,不是同时300啊!
  • 跪求:linux下pthread 双线程计算和单线程的运行时间完全相同是为什么?
  • linux线程与进程的问题
  • linux 下子线程不能执行的问题?
  • linux多线程编程的问题
  • linux多线程编程
  • linux僵尸(zombie)进程介绍及清除
  • 高手请教!linux怎样通过pid获取进程信息,如:进程名、进程状态等?
  • linux下进程占用内存空间详解
  • linux命令如何实现重启父进程而不会使其子进程退出
  • Linux进程的内核栈和用户栈概念,相互关系及切换过程
  • Linux中最多同时可以开多少个进程,一个进程可以开多少个线程?
  • linux下进程间通信:共享内存原理及具体用法举例(基于c/c++语言)
  • Linux守护进程 的子进程 终端处理
  • Linux内核进程与应用进程的通信方式有哪些?
  • 在linux,如何用共享内存来实现进程间的通讯?(这些进程没有父子关系)
  •  
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • linux内核分配内存,及管理?
  • 问个LINUX内存分配的问题。
  • linux c 多线程问题任务分配问题
  • Linux 如何获得分配内存的起始地址
  • linux下具体分配组的访问目录
  • 请教Linux内存分配策略与Windows有何异同?
  • Linux下服务器端的线程分配
  • 偶托管了一管台linux主机,想分配一个用户出来自已用,请问该怎么做?
  • 我在linux下用GPRS拨号上网,拨号分配到的IP是10.98.*.*时为何访问不了公网呢?
  • 关于Linux内存分配函数的几点问题
  • 请问如何在linux下设置为动态地址分配
  • 如何重新分配linux分区
  • Linux Kernel module下如何动态分配内存
  • 请教一个Linux内存分配的问题
  • linux服务器被电信重新分配了IP,结果proftp不能启动了。
  • 嵌入式linux的应用程序分配内存地址问题
  • 关于Linux系统对进程号的分配问题
  • linux权限的分配问题
  • linux下c++对长度不定的字符串要进行预先动态分配内存需要怎么做?
  • linux的usb驱动在分配设备节点时是如何做的?
  • linux c/c++ IP字符串转换成可比较大小的数字
  • 在win分区上安装linux和独立分区安装linux有什么区别?可以同时安装吗?(两个linux系统)
  • linux哪个版本好?linux操作系统版本详细介绍及选择方案推荐
  • 在虚拟机上安装的linux上,能像真的linux系统一样开发linux程序么?
  • secureCRT下Linux终端汉字乱码解决方法
  • 我重装window后,把linux的引导区覆盖了,进不了linux怎么办?急啊,望热心的人帮助 (现在有linux的盘)
  • Linux c字符串中不可打印字符转换成16进制
  • 安装vmware软件,不用再安装linux系统,就可以模拟linux系统了,然后可以在其上学习一下LINUX下的基本操作 了?
  • Linux常用命令介绍:更改所属用户群组或档案属性
  • 红旗Linux主机可以通过127.0.0.1访问,但如何是连网的Win2000机器通过Linux的IP去访问Linux
  • linux命令大全详细分类介绍及常用linux命令文档手册下载


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3