-
什么是进程
2.1 进程的概念
进程是程序的一次动态执行过程,包括创建、调度、消亡
2.2 进程和程序的区别
程序(a.out)是静态的,它是一些保存在磁盘上的指令的有序集合,没有任何执行的概念
进程(./a.out)是一个动态的概念,它是程序执行的过程,包括创建、调度和消亡
2.3 进程是程序执行和资源(内存)管理的最小单位
为什么说进程是程序执行和资源管理的最小单位?
因为每一个进程都有一个0~4G的虚拟内存
为什么要有虚拟内存?--->多任务、安全
2.4 如何区分不同的进程-->PID(进程号)
进程是由进程创建的,我们有父进程和子进程
2.5 进程的类型
(1)交互进程:该类进程是由shell控制和运行的。交互进程既可以在前台运行,也可以在后台运行。
在前台运行:
后台运行:
(2)批处理进程:该类进程不属于某个终端,它被提交到一个队列中以便顺序执行。
(3)守护进程:该类进程在后台运行。它一般在Linux启动时开始执行,系统关闭时才结束。
2.6 进程运行状态
(1)运行态:此时进程或者正在运行,或者准备运行。
(2)等待态:此时进程在等待一个事件的发生或某种系统资源。
可中断
不可中断
(3)停止态:此时进程被中止。
(4)僵死态:这是一个已终止的进程,但还在进程向量数组中占有一个task_struct结构体。
为了更好的管理Linux所访问的资源,系统在内核头文件include/linux/sched.h定义了进程控制块(PCB)结构体task_struct来管理每个进程的资源
内核空间进程资源即PCB相关的信息,包括进程控制块本身,打开的文件表项、当前目录、当前终端信息、线程基本信息、可以访问内存地址空间、PID、PPID、UID、EUID等,也就是说,内核通过PCB结构体可以访问到进程的所有资源信息
(5)死亡态
2.7 进程的模式
用户模式和内核模式
2.8 进程相关的的系统调用
2.8.1 fork
头文件:
#include <sys/types.h>
#include <unistd.h>
函数原型:
pid_t fork(void);
注意:1.fork是子进程完全拷贝父进程用户空间和大部分进程信息
2.子进程只执行fork之后的程序
注意:子进程执行是在fork函数的返回处
2.8.2 getpid、getppid
getpid为获取该进程的pid,getppid为获取该进程父进程的pid
2.8.3 进程退出
exit、_exit、return(主函数的return)
exit和_exit作用相同,但exit清除缓冲区,_exit不清楚缓冲区
2.8.4 孤儿进程
父进程先于子进程退出,子进程会被systemd进程收养,子进程会变成后台进程
2.8.5 僵尸进程
子进程先退出,父进程没有及时回收子进程的资源(PCB结构体),此时就成为了僵尸进程
注意:父进程不退出,子进程会一直保持僵死状态,直到父进程退出,被systemd回收
2.8.6 wait、waitpid
如何避免僵尸进程,子进程退出时父进程及时回收子进程的资源,可以调用wait或者waitpid
wait在回收子进程资源时会阻塞,当我们不阻塞时可以用waitpid
2.9 exec函数族
l:list 以列表的形式传参
v:vector 数组
p:path 系统会自动从环境变量“$PATH”所包含的路径中进行查找。
守护进程
特点
- 从系统启动开始运行,系统关闭时停止运行
- 后台进程,与终端无关
想要实现守护进程:
(1)不能和终端具有亲缘关系
(2)与终端无关,也就是要把控制终端变成?
守护进程的创建步骤
创建子进程,父进程退出
在子进程中创建新会话
改变当前目录为根目录
重设文件权限掩码
关闭文件描述符
通信的相关概念
通信的模式
单工:A-->B (键盘输入)
半双工:A--->B 或者 B--->A (对讲机)
双工:A--->B 同时 B-->A(打电话)
同步:(走路)
异步:(外卖)
通信方式
无名管道
注意:
(1)当管道中无数据时,读操作会阻塞
(2)向管道中写入数据时,linux将不保证写入的原子性,管道缓冲区一有空闲区域,写进程就会试图向管道写入数据。如果读进程不读走管道缓冲区中的数据,那么写操作将会一直阻塞。
(3)只有在管道的读端存在时,向管道中写入数据才有意义。否则,向管道中写入数据的进程将收到内核传来的SIGPIPE信号(通常Broken pipe错误)-->管道破裂
有名管道
信号
alarm
pause
pause()函数是用于将调用进程挂起直到收到信号为止
kill
发送信号给进程或进程组
raise
raise函数允许进程向自己发送信号
共享内存
共享内存的创建步骤
创建/打开共享内存
映射共享内存,即把指定的共享内存映射到进程的地址空间用于访问
撤销共享内存映射
删除共享内存对象
有名信号量
有名信号量:进程间的同步
无名信号量:线程间的同步
消息队列
消息队列的创建步骤
发送端:
- 创建并打开消息队列
- 添加消息
- 接收消息
- 删除消息队