什么是进程
进程的概念
进程是处于执行期的程序和他所占用资源的总称。进程就是运行的代码,进程的声明从代码开始运行那一刻开始;单纯的程序并非是是一个进程,一个程序也可能不只包含一个进程。
进程和线程的区别,与联系
线程是进程中的活动对象,每个线程都有一个独自程序计数器,进程栈和一个独立的进程寄存器。内核调度的对象是线程而不是进程,
线程是进程的组成部分,一个进程中可能包含多个线程。同一个进程中的不同线程之间可以共享内存空间,但是各个线程之间需要独占计算资源。在Linux系统当中,线程就是特殊的进程。
进程描述符及任务结构
内核中将描述进程的结构体存放在一个叫任务队列的结构体中,任务队列是一个双向循环链表。链表中的每一项都是类型为task_struct、称为进程描述符的结构,该结构定义在<linux/sched.h>的文件中。
进程描述符的分配
Linux通过slab分配器分配task_struct结构,这样能达到内存分配和缓存着色(通过预先分配和重复使用task_struct,可以避免动态分配和释放带来的资源消耗)。由于现在使用slab分配器分配task_struct结构,只需在栈顶(向上增长)或者栈底(向下增长)创建一个新的结构struct thread_info。
x86中thread_info的结构定义
进程描述符的存放
内核通过为一个进程标示值或者PID来标识每个进程;PID的最大默认值为32768。系统管理员可以通过修改/proc/sys/kernel/pid_max来修改pid的最大值。