Linux一个进程最多能开启的线程数

2019-07-14 12:19发布

class="markdown_views prism-atom-one-light">

PCB(进程控制块)

对于一个进程,它在被执行前是一个可执行程序。这个程序是被放在磁盘上的,当它要被执行的时候,它先被加载到内存当中,然后再放入到寄存器中,最后再让cpu执行该程序,这个时候一个静态的程序就变成了进程。

操作系统如何管理进程

操作系统用一个双向链表把进程连起来,但是进程是一个抽象的概念,于是系统用一个东西来描述进程,进而管理进程。这个东西就是PCB,双向链表链接的就是PCB。PCB在Linux下其实就是一个task_struct结构体。

进程内存分配

每个进程运行的时候,都会拿到4G的虚拟内存,在32位Linux下,其中3G是给用户使用的,1G是给内核使用,task_struct就是存储在这1G的内核系统空间中。
每个进程都有各自的私有用户空间(0-3G),这个空间对系统中的其他进程是不可见的。
最高的1GB内核空间则为所有进程以及内核所共享。
因为进程有时候需要进行一些系统调用,来让内核操作,所以一部分虚拟地址必须要留给内核使用。
每个进程的PCB都是存在所有进程共享的内核空间的中,这也就很好理解,我们之前说操作系统管理进程,也就是在内核空间中管理的,在内核空间中通过链表管理所有进程的PCB,如果有一个进程要被创建,实际上多分配了这么一个4G的虚拟内存,并在共享的内核空间中的双向链表中加入了自己的PCB。
在这里插入图片描述

一个进程中最多可以有多少个线程

创建一个线程取决于分配给线程的调用栈的大小,使用ulimit -s命令可以来查看(一般是10M),创建一个线程占有了10M内存,而总共有3G内存可以供用户使用,因此,最多可以创建差不多300左右的线程。

线程数的限制条件

  • 操作系统(32位或者64位)
  • 分配给每个线程的调用栈的大小
  • 默认一个用户只能创建1024个进程