一、进程
1、基本概念
狭义定义:进程是正在运行的程序的实例(an instance of a computer program that is being executed)。
广义定义:进程是一个具有一定独立功能的程序关于某个数据集合的一次运行活动。它是操作系统动态执行的基本单元,在传统的操作系统中,进程既是基本的分配单元,也是基本的执行单元。
2、进程–PCB
(1)每个进程在内核中都有一个进程控制块(PCB)来维护进程相关的信息,其作用是使一个在多道程序环境下不能独立运行的程序成为一个能独立运行的基本单位或其他进程并发执行的进程。
(2)PCB是系统感知进程存在的唯一标识。
(3)Linux内核的进程控制块是task_struct结构体。task_struct是Linux内核的一种数据结构。它会被装载到RAM里并且包含着进程的信息。它定义在linux-2.6.38.8、include/linux/sched.h文件中。task_steuct结构体包含了以下内容:
标⽰符: 描述本进程的唯⼀一标示符,⽤用来区别其他进程。
状态: 任务状态,退出代码,退出信号等。
优先级: 相对于其他进程的优先级。
程序计数器: 程序中即将被执⾏行的下⼀一条指令的地址。
内存指针: 包括程序代码和进程相关数据的指针,还有和其他进程共享的内存块的指针
上下⽂文数据: 进程执⾏行时处理器的寄存器中的数据[休学例⼦子,要加图CPU,寄存器]。
I/O状态信息: 包括显⽰示的I/O请求,分配给进程的I/O设备和被进程使⽤用的⽂文件列表。
记账信息: 可能包括处理器时间总和,使⽤用的时钟数总和,时间限制,记账号等。
其他信息
二、进程的创建
1、fork函数
在Linux中fork函数是非常重要的函数,它从已存在进程中创建一个新的进程;新创建的进程被称为子进程,原来的进程就是父进程。
返回值:子进程中返回0,父进程返回子进程id,出错返回-1;
当进程调用fork,控制块转移到内核中的fork代码后,内核需要做以下工作:
(1)分配新的内存块和内核数据结构给⼦子进程
(2)将⽗父进程部分数据结构内容拷⻉贝⾄至⼦子进程
(3)添加⼦子进程到系统进程列表当中
(4)fork返回,开始调度器调度
fork函数—创建进程实例代码:
1 #include<stdio.h>
2 #include<unistd.h>
3 #include<stdlib.h>
4
5
6 int main(void)
7 {
8 pid_t pid;
9
10 printf("Before:pid is %d\n",getpid());//创建子进程之前的进程id