30.进程池IPC

进程池代码的问题:

常见子进程,关父进程关闭读3,用4写,再创建子进程,父进程用3读,用5写,第二个子进程还是用3读。但是第二个子进程可能继承4写,这样的话还有别的引用计数,不能彻底关掉,那么就阻塞,读端不会读到0.所以不能把stop和wait写到一个for循环

所以方法1:从下往上关,就行,方法2:就让一个指向一个文件描述符,让下一个把继承的哥哥进程的w端关了就行。调用closeall就能全部关掉看代码

,父进程每次创建完管道子进程都会把管道和子进程给cm容器,子进程创建时候会继承父进程数据,cm就是历史上打开的文件描述符的写端。第一次创建时候cm是空,close什么都没做,第二次创建时候,已经保存第一次创建的文件描述符所以关闭时候所以只有第一个进程文件描述符写端。父进程修改会发生写时拷贝 。

看代码。


命名管道:

为什么要有两个struct file;因为每个进程读写位置不一样,但是操作系统根据inode number发现同一个文件后 所以struct file指向同样inode 文件缓冲区,

磁盘会刷新到外面,所以有个管道文件,

创建命名管道,p开头文件类型

echo就是个进程,向管道写入,cat也是个进程,这就是进程间通信。这就是命名管道。

unlink fifo就删掉了

如何用代码实现命名管道。就是让一个进程创建一个命名管道,后面就是文件操作。

系统调用:

mode代表读还是写

lesson25看看代码

相关推荐
xcLeigh2 分钟前
KES数据库表空间目录自动创建特性详解与存储运维最佳实践
大数据·运维·服务器·数据库·表空间·存储
零二年的冬9 分钟前
epoll详解
java·linux·开发语言·c++·链表
weixin_4493108411 分钟前
电商对账革命:破解效率困局,拥抱自动化转型
运维·自动化
Agent产品评测局14 分钟前
企业工单处理自动化落地,派单回访全流程闭环实现:2026架构升级与多方案全景盘点
运维·人工智能·ai·架构·自动化
问简21 分钟前
ubuntu 输入法优化
linux·运维·ubuntu
勤自省22 分钟前
Windows 文件无法粘贴到 Linux(Ubuntu)系统的解决方案
linux·windows·ubuntu
Bert.Cai38 分钟前
Linux tail命令详解
linux·运维
舒一笑1 小时前
AI 系统落地难的,从来不只是模型:一次企业级部署实施复盘
运维·后端·程序员
sbjdhjd1 小时前
Docker | 核心概念科普 + 保姆级部署
linux·运维·服务器·docker·云原生·面试·eureka
charlie1145141911 小时前
嵌入式C++教程实战之Linux下的单片机编程(9):HAL时钟使能 —— 不开时钟,外设就是一坨睡死的硅
linux·开发语言·c++·单片机·嵌入式硬件·c