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个进程