1.kill()可以杀死进程
Int kill(pid_t,int sig);
-2:ctrl c -9:彻底杀死
2.进程间通信
①管道:
特性:
- 管道是单向的,数据只能从左到右
- 管道实际上会创建子进程来执行命令
- 管道中的命令是并行执行的
- 管道可以串联,形成管道链
有名管道:通过mkfifo 管道名
特性:
- 有可见的文件名(存在于文件系统中)
- 可以被任意进程(需要有权限)访问
- 数据传输遵循先进先出原则
- 本质上是内存中的特殊文件,不占用磁盘空间
- 关闭所有引用他的进程后,管道文件依然存在(需要手动删除)
测试一:在命令行去输入信息
读端,持续监听管道 cat < 管道文件 持续读取 while true;do cat < 管道文件;done
写端,多次写入内容 cat > 管道文件
测试二:在文件中写入和读取
读文件:使用raed函数写入管道文件,注意read函数第三个参数不能是初始化的strlen
写文件:使用write函数写数据到管道文件中
无名管道:无名称,仅通过文件描述符访问
特性:
- 仅支持亲缘进程:父子,兄弟
- 创建方式:pipe()系统调用
- 生命周期:随进程结束而销毁
|-------|-----------|----------|
| | 有名管道 | 无名管道 |
| 名称 | 存在文件系统中 | 不在文件系统中 |
| 进程的关系 | 任意进程 | 父子,兄弟 |
| 生命周期 | 文件系统销毁而销毁 | 随进程销毁而销毁 |
| 创建方式 | mkfifo | Pipe |
注意事项:
- 避免管道破裂,其中读端已关闭的情况下,写端还在输出数据,会触发sigpipe信号,终止写端进程
- 数据无边界:管道是字节数据流,若按照消息的格式,一条一条发送,需要自定义信息格式(长度+数据),避免多读少读
- 缓冲区的阻塞问题:读空,写满会阻塞进程,所以会需要fcntl()设置属性进行处理
- 资源泄露问题:进程退出前提前关闭管道描述符,会导致缓冲区中的数据丢失