Linux匿名管道

目录

1.原理

1.直接原理

2.本质原理

2.管道接口

3.管道中的四种情况

1.读写端正常,管道如果为空,读端就要堵塞

2.读写端正常,管道如果被写满,写端就要堵塞

3.读端正常,写端关闭,读端就会读到0,表明读到文件(pipe)结尾,不会被堵塞

4.写端正常,读端关闭,操作系统就要杀掉正在写入的进程。(通过信号杀掉)

4.匿名管道特性

5.运用的场景模拟代码


1.原理

1.直接原理

由于进程具有独立性,要两个进程进行通信是要代价的,所以其本质是让不同的进程看到同一份资源!管道也可以看成文件!

2.本质原理

我们假设让父进程进行读取,子进程进行写入:

记住改文件没有inode文件属性和文件名字,因为该文件不需要其他人进行访问,知道其文件描述符(文件数组下标)就可以了。

2.管道接口

有些人好奇,一般不都是int pipefd[]这样子的形参吗?但这边是特意告诉我们这里的数组只需要传两个大小int的数组,piprfd[0]表示读下标,pipefd[1]表示写下标(这其实很好记住,0是嘴巴o--读,1是笔--写):

由此可知:所以只有具有血缘关系的进程才能通过匿名管道进行通信!

3.管道中的四种情况

1.读写端正常,管道如果为空,读端就要堵塞

上面就是这个情况,写端中有sleep1,读端就自动在堵塞等待。

2.读写端正常,管道如果被写满,写端就要堵塞

但是到底管道到底有多大呢?

这边显示4KB,但是我们试验一下呢?

一个实验是64KB, 但是ulimit -a 中显示的是4kb,其实pipe函数说明中有一个PIPE_BUF

man 7 pipe:

所以我们就把它当成PIPE_BUF就好了,那这个是什么呢?就是比如写端在写hello world,但写到hello后读端开始读了,可能只读了hello,因此只要写端没超过4kb,还在写的过程中,读端是不会读的!

3.读端正常,写端关闭,读端就会读到0,表明读到文件(pipe)结尾,不会被堵塞

4.写端正常,读端关闭,操作系统就要杀掉正在写入的进程。(通过信号杀掉)

sign pipe

4.匿名管道特性

1.具有血缘关系的进程进行进程间通信。

2.管道只能单向通信

3.父子进程是会进程协同的,同步与互斥--保护管道文件的数据安全

4.管道是面向字节流的

5.管道是基于文件的,而文件的生命周期是随进程的!

5.运用的场景模拟代码

相关推荐
赖small强1 分钟前
【Linux C/C++开发】 GCC -g 调试参数深度解析与最佳实践
linux·c语言·c++·gdb·-g
white-persist11 分钟前
VSCode 快捷键大全:从设计理念到场景化高效运用(详细解析)(文章末尾有vim快捷键大全)
linux·ide·vscode·python·编辑器·系统安全·vim
杭州泽沃电子科技有限公司28 分钟前
煤化工精炼与加工环节的监测:智能平台如何保障最终产品价值与环保合规?
运维·科技
可可苏饼干1 小时前
Ruo-Yi 前后端分离
运维·学习
SUPER52661 小时前
运维hbase服务重启,导致应用查询异常 hbase:meta
运维·数据库·hbase
_w_z_j_1 小时前
Linux----信号(产生、保存、处理)
linux·运维·服务器
专家大圣1 小时前
远程调式不复杂!内网服务器调试用对工具很简单
运维·服务器·网络·内网穿透·cpolar
集大周杰伦1 小时前
RV1126开发板烧录与SSH登录实践
linux·ssh·嵌入式·rv1126·瑞芯微开发工具·ssh 远程登录
gs801401 小时前
Ascend 服务器是什么?(Ascend Server / 昇腾服务器)
运维·服务器·人工智能
Xの哲學1 小时前
Linux RTC深度剖析:从硬件原理到驱动实践
linux·服务器·算法·架构·边缘计算