Linux进程间通信:匿名管道 命名管道
Linux进程间通信:匿名管道 &命名管道
- 一、进程间通信目的
- 二、什么是管道
- 三、匿名管道创建
- 3.1 系统调用原型
- 3.2 匿名管道创建
- 四、内核创建匿名管道过程
- 五、匿名管道性质
- 5.1 匿名管道的4种特殊情况
- 5.2 匿名管道的5种特性
- 5.3 测试源代码
- 六、命名管道
- 6.1 创建命名管道
- 1. 命名行创建
- 6.2 代码中创建
- 七、命名管道性质
- 7.1 匿名管道与命名管道的区别
- 7.2 命名管道的打开规则
- 八、进程池制作(基于匿名管道和命名管道两个版本)
一、进程间通信目的
进程间通信的本质是不同进程看到同一份资源。该资源一般由操作系统提供!!(比如缓冲区)
进程间通信目的主要有:
- 数据传输:一个进程需要将它的数据发送给另一个进程。
- 资源共享:多个进程之间共享同样的资源。
- 通知事件:一个进程需要向另一个或一组进程发送消息,通知它(它们)发生了某种事件(如进程终止时要通知父进程)。
- 进程控制:有些进程希望完全控制另一个进程的执行(如Debug进程),此时控制进程希望能够拦截另一个进程的所有陷入和异常,并能够及时知道它的状态改变。
二、什么是管道
管道最早是UNIX中的一种进程通信方式。我们把一个进程到另一个进程的一个数据流称为管道!!管道文件时一个纯内存级文件,不需要想磁盘刷新。

三、匿名管道创建
3.1 系统调用原型
系统中提供了系统调用接口pipe()用于创建匿名管道。
#include <unistd.h>int pipe(int pipefd[2]);
pipefd为输出型参数,pipefd[1]为写端,pipefd[0]为读端!!- 创建成功返回0,否则返回-1.
此时创建结果如下:

3.2 匿名管道创建


四、内核创建匿名管道过程
在一个进程中,我们分别通过r和w两种方式打开同一个文件,此时进程文件描述符表中存在两个文件描述符fd,指向两个文件结构体对象file。但两个结构体对象指向同一个文件(即相同的inode、同一个方法集、同一块缓冲区)!!


此时我们通过fork()创建出子进程,子进程继承了父进程的file结构体对象!(新创建的文件属于文件管理,不属于进程管理,所以不需要给子进程也拷贝一份!)

此时我们将父进程的写段关闭,子进程的读端关闭(即子写父读)。此时我们就形成了一个匿名管道(父子两个进程都看到同一份资源:文件缓冲区;数据从子进程写入到文件中,父进程从文件中读取数据,形成数据流)

- 上述这种文件和普通文件不同,不会向磁盘刷新数据。并且文件的缓冲区是父进程和子进程所能看到的同一份资源,而向这种文件我们称之为管道。该管道没有名字,所以被称为匿名管道!!
五、匿名管道性质
5.1 匿名管道的4种特殊情况
- 正常情况下,如果管道数据为空,此时读端必读等待,直到有数据为止(写段向管道中写入数据)
- 正常情况下,如果管道数据写满,此时写端会停止写入,直到有空间为止!!
- 如果写端关闭,读端一直读取,读端读取到的read返回值为0
- 如果读端关闭,写端一直写入,此时操作系统会通过向写端发送13号信号,直接杀掉写端进程。
5.2 匿名管道的5种特性
- 匿名管道仅用于具有血缘关系的进程间进行相互通信,常用于父子进程间。
- 匿名管道默认会给读写端提供同步机制。即管道为空,读端等待写端写入;管道满了,写端等待读端读取。
- 匿名管道面向字节流,即通过read读取指定大小数据,数据过小不会读取
- 管道的生命周期随进程。当进程全部退出时,此时管道的引用计数减为0,操作系统会将管道文件释放。
- 匿名管道具有单向通信特点,是半双工通信的一种特殊情况,数据只能向一个方向流动。
- 匿名管道具有原子性。当要写入的数据量不大于PIPE_BUF时,linux将保证写入的原子性。即当管道中的数据量小于PIPE_BUF和指定大小时,此时读端会等待子进程写入。当要写入的数据量大于PIPE_BUF时,linux将不再保证写入的原子性。
5.3 测试源代码
#include <iostream>
#include <cassert>
#include <cstdlib>
#include <cstring>
#include <sys/types.h>
#include <sys/wait.h>
#include <unistd.h>using namespace std;#define MAX 1024int main()
{//1. 创建管道int pipefd[2];int n = pipe(pipefd);assert(n == 0);(void)n;// 2. 创建子进程pid_t id = fork();if(id < 0){perror("fork");return 1;}//3. 关闭不需要的fd, 形成匿名管道int cnt = 5;if(id == 0)//child{close(pipefd[0]);//子进程关闭读端while(true){char message[MAX];// snprintf把原本打印到显示器的信息打印到指定文件中snprintf(message, sizeof(message), "I am child, pid: %d, cnt: %d", getpid(), cnt--);write(pipefd[1], message, strlen(message));//sleep(1);if(cnt == 0) break;cout << "write----" << endl;}cout << "child quit" << endl;exit(0);}//parentclose(pipefd[1]);//父进程关闭写端while(true){// sleep(1);char buffer[MAX];// read 把pipefd[0]对于文件中最大517个字节写入buffer缓冲区中ssize_t n = read(pipefd[0], buffer, 517);if(n == 0){cout << "child quit, me too" << endl;break;}else if(n > 0){buffer[MAX - 1] = 0;cout << "chils say:" << buffer << endl;}break;}cout << "parent quit" << endl;close(pipefd[0]);//回收子进程int status;pid_t rid = waitpid(id, &status, 0);if(rid == id){cout << "wait child: " << id << "success" << "exit singal" << (status&0x7f) << endl;}return 0;
}
六、命名管道
匿名管道中能在具有血缘关系的进程间,进行相互通信。那两个毫无关系的独立进程该如何通信了?
在不相关的进程之间交换数据,可以使用FIFO文件来做这项工作的管道称为命名管道。命名管道是一种特殊类型的文件。
6.1 创建命名管道
1. 命名行创建
我们可以在命令行上创建命名管道,创建方式如下:
mkfifo xxx
【实例】:

6.2 代码中创建
我们也可以在代码中使用系统调用接口创建,函数原型如下:
#include <sys/types.h>
#include <sys/stat.h>int mkfifo(const char *filename,mode_t mode);// mode为带创建管道权限
七、命名管道性质
7.1 匿名管道与命名管道的区别
- 匿名管道由pipe函数创建并打开;命名管道由mkfifo函数创建,打开用open。
- FIFO(命名管道)与pipe(匿名管道)之间唯一的区别在它们创建与打开的方式不同,一但这些工作完
成之后,它们具有相同的语义
7.2 命名管道的打开规则
如果当前打开操作是为读而打开FIFO时:
- O_NONBLOCK disable:阻塞直到有相应进程为写而打开该FIFO。
- O_NONBLOCK enable:立刻返回成功
如果当前打开操作是为写而打开FIFO时:
- O_NONBLOCK disable:阻塞直到有相应进程为读而打开该FIFO。
- O_NONBLOCK enable:立刻返回失败,错误码为ENXIO。
八、进程池制作(基于匿名管道和命名管道两个版本)
Linux:进程池制作(基于匿名管道和命名管道两个版本)
相关文章:
Linux进程间通信:匿名管道 命名管道
Linux进程间通信:匿名管道 &命名管道 一、进程间通信目的二、什么是管道三、匿名管道创建3.1 系统调用原型3.2 匿名管道创建 四、内核创建匿名管道过程五、匿名管道性质5.1 匿名管道的4种特殊情况5.2 匿名管道的5种特性5.3 测试源代码 六、命名管道6.1 创建命名…...
【数据结构】(C语言):二叉搜索树(不使用递归)
二叉搜索树: 非线性的,树是层级结构。基本单位是节点,每个节点最多2个子节点。有序。每个节点,其左子节点都比它小,其右子节点都比它大。每个子树都是一个二叉搜索树。每个节点及其所有子节点形成子树。可以是空树。 …...
Fastapi在docekr中进行部署之后,uvicorn占用的CPU非常高
前一段接点小活,做点开发,顺便学了学FASTAPI框架,对比flask据说能好那么一些,至少并发什么的不用研究其他的asgi什么的,毕竟不是专业开发,能少研究一个东西就省了很多的事。 但是部署的过程中突然之间在do…...
Pandas数据可视化宝典:解锁图形绘制与样式自定义的奥秘
Pandas数据可视化宝典:解锁图形绘制与样式自定义的奥秘 引言 数据可视化是将数据以图形或图像的形式展示出来,使复杂的数据更容易被人类理解和分析。在数据分析、商业智能、科学研究等领域,数据可视化都扮演着至关重要的角色。Pandas作为一…...
2024前端面试真题【JS篇】
DOM DOM:文本对象模型,是HTML和XML文档的编程接口。提供了对文档的结构化的表述,并定义可一种方式可以使从程序中对该结构进行访问,从而改变文档的结构、样式和内容。 DOM操作 创建节点:document.createElement()、do…...
axios使用sm2加密数据后请求参数多了双引号解决方法
axios使用sm2加密数据后请求参数多了双引号解决 背景问题描述解决过程 背景 因项目安全要求,需对传给后端的入参加密,将请求参数加密后再传给后端 前期将axios降低到1.6.7后解决了问题,但最近axios有漏洞,安全要求对版本升级&…...
MybatisPlus 核心功能
MybatisPlus 核心功能 文章目录 MybatisPlus 核心功能1. 条件构造器1.1 QueryWrapper1.2 LambdaQueryWrapper(推荐)1.3 UpdateWrapper1.4 LambdaUpdateWrapper 2. 自定义SQL3. Service接口 1. 条件构造器 当涉及到查询或修改语句时,MybatisP…...
vivado EQUIVALENT_DRIVER_OPT、EXCLUDE_PLACEMENT
Vivado工具将所有逻辑上等效的信号的驱动程序合并为单个驱动程序 在逻辑优化过程中指定-merge_equivalent_drivers选项时 (opt_design)。请参阅《Vivado Design Suite用户指南:实施》中的此链接 (UG904)[参考文献20]了…...
docker也能提权??内网学习第6天 rsync未授权访问覆盖 sudo(cve-2021-3156)漏洞提权 polkit漏洞利用
现在我们来说说liunx提权的操作:前面我们说了环境变量,定时任务来进行提权的操作 rsync未授权访问覆盖 我们先来说说什么是rsync rsync是数据备份工具,默认是开启的873端口 我们在进行远程连接的时候,如果它没有让我们输入账号…...
TF卡病毒是什么?如何防范和应对?
在存储芯片及存储卡领域,TF卡病毒是一个备受关注的话题。在本文中,拓优星辰将详细解释TF卡病毒的含义、来源以及如何防范和应对这一问题,帮助客户更好地了解和处理TF卡病毒的风险。 1. TF卡病毒的含义 TF卡病毒是指针对TF存储卡(T…...
window对象监听浏览器页签之间的切换状态;前端监听浏览器切换页签的触发时机
window对象监听浏览器页签之间的切换状态 记录两种办法 第一种:会将任何鼠标点进或点出浏览器的操作监听;同页面也会触发 // 窗口获得焦点时的回调函数 function onWindowFocus() {console.log(窗口获得焦点);querySubmit() } // 窗口失去焦点时的回调函…...
MySQL 条件函数/加密函数/转换函数
条件函数 IF(): 如果条件为真,返回一个值,否则返回另一个值。 -- 示例:根据员工的薪水返回薪水等级 SELECT name, salary, IF(salary < 3000, Low, IF(salary BETWEEN 3000 AND 7000, Medium, High)) AS salary_level FROM employ…...
初学SpringMVC之接收请求参数及数据回显
pom.xml 文件导入 lombok 的依赖 <dependency><groupId>org.projectlombok</groupId><artifactId>lombok</artifactId><version>1.18.34</version></dependency> Controller 表示这是一个控制器 RequestParam 表示从前端接收…...
Java链表LinkedList经典题目
一.LinkedList的方法 首先先看一下链表的方法: 方法解释boolean add(E e)尾插void add(int index, E element)将 e 插入到 index 位置boolean addAll(Collection c)尾插 c 中的元素E remove(int index)删除 index 位置元素boolean remove(Object o)删除遇到的第一…...
【cocos creator】2.x,伪3d拖拽,45度视角,60度视角,房屋装扮
伪3d拖拽,45度视角,60度视角 工程下载:(待审核) https://download.csdn.net/download/K86338236/89530812 dragItem2.t s import mapCreat2 from "./mapCreat2";const {ccclass, property } = cc._decorator; /*** 拖拽类,挂在要拖拽的节点上*/ @ccclass export…...
【thingsbord源码编译】 显示node内存不足
编译thingsbord显示报错 FATAL ERROR: CALL_AND_RETRY_LAST Allocation failed - JavaScript heap out of memory问题原因分析 重新安装java版本 编译通过...
内存巨头SK海力士正深化与TSMC/NVIDIA合作关系,开发下一代HBM
据BusinessKorea报道,内存巨头SK海力士正深化与台积电(TSMC)及英伟达(NVIDIA)的合作关系,并计划在9月的台湾半导体展(Semicon Taiwan)上宣布更紧密的伙伴关系。 SK海力士与台积电的合作历史已久。2022年,台积电在其北美技术研讨会上宣布成立O…...
基于Pinia的WebSocket管理与优化实践(实现心跳重连机制,异步发送)
WebSocket作为一种全双工通信协议,允许服务器和客户端之间建立持久的连接,提供了比传统HTTP请求更为高效的数据交换方式。本文将探讨如何使用Pinia状态管理库在Vue应用中优雅地管理和优化WebSocket连接,以实现稳定、高效的实时数据传输。 环境…...
Perl词法作用域:自定义编程环境的构建术
🎭 Perl词法作用域:自定义编程环境的构建术 在Perl编程中,词法作用域(lexical scoping)是一种控制变量可见性的方式,它允许变量在特定的作用域内可见,从而避免变量名的冲突。Perl提供了灵活的机…...
vscode使用ssh连接远程服务器
开工啦 vscode连接远程服务器(傻瓜式教学) 正常根据上面文章的步骤就可以连接了 报错可以尝试的文章: VScode通过remote ssh连接虚拟机 & 报错过程试图写入的管道不存在(已解决) vscode remote ssh linux[血泪…...
Qt Widget类解析与代码注释
#include "widget.h" #include "ui_widget.h"Widget::Widget(QWidget *parent): QWidget(parent), ui(new Ui::Widget) {ui->setupUi(this); }Widget::~Widget() {delete ui; }//解释这串代码,写上注释 当然可以!这段代码是 Qt …...
el-switch文字内置
el-switch文字内置 效果 vue <div style"color:#ffffff;font-size:14px;float:left;margin-bottom:5px;margin-right:5px;">自动加载</div> <el-switch v-model"value" active-color"#3E99FB" inactive-color"#DCDFE6"…...
uniapp中使用aixos 报错
问题: 在uniapp中使用aixos,运行后报如下错误: AxiosError: There is no suitable adapter to dispatch the request since : - adapter xhr is not supported by the environment - adapter http is not available in the build 解决方案&…...
[Java恶补day16] 238.除自身以外数组的乘积
给你一个整数数组 nums,返回 数组 answer ,其中 answer[i] 等于 nums 中除 nums[i] 之外其余各元素的乘积 。 题目数据 保证 数组 nums之中任意元素的全部前缀元素和后缀的乘积都在 32 位 整数范围内。 请 不要使用除法,且在 O(n) 时间复杂度…...
安宝特案例丨Vuzix AR智能眼镜集成专业软件,助力卢森堡医院药房转型,赢得辉瑞创新奖
在Vuzix M400 AR智能眼镜的助力下,卢森堡罗伯特舒曼医院(the Robert Schuman Hospitals, HRS)凭借在无菌制剂生产流程中引入增强现实技术(AR)创新项目,荣获了2024年6月7日由卢森堡医院药剂师协会࿰…...
Java编程之桥接模式
定义 桥接模式(Bridge Pattern)属于结构型设计模式,它的核心意图是将抽象部分与实现部分分离,使它们可以独立地变化。这种模式通过组合关系来替代继承关系,从而降低了抽象和实现这两个可变维度之间的耦合度。 用例子…...
Python Einops库:深度学习中的张量操作革命
Einops(爱因斯坦操作库)就像给张量操作戴上了一副"语义眼镜"——让你用人类能理解的方式告诉计算机如何操作多维数组。这个基于爱因斯坦求和约定的库,用类似自然语言的表达式替代了晦涩的API调用,彻底改变了深度学习工程…...
STM32---外部32.768K晶振(LSE)无法起振问题
晶振是否起振主要就检查两个1、晶振与MCU是否兼容;2、晶振的负载电容是否匹配 目录 一、判断晶振与MCU是否兼容 二、判断负载电容是否匹配 1. 晶振负载电容(CL)与匹配电容(CL1、CL2)的关系 2. 如何选择 CL1 和 CL…...
C语言中提供的第三方库之哈希表实现
一. 简介 前面一篇文章简单学习了C语言中第三方库(uthash库)提供对哈希表的操作,文章如下: C语言中提供的第三方库uthash常用接口-CSDN博客 本文简单学习一下第三方库 uthash库对哈希表的操作。 二. uthash库哈希表操作示例 u…...
go 里面的指针
指针 在 Go 中,指针(pointer)是一个变量的内存地址,就像 C 语言那样: a : 10 p : &a // p 是一个指向 a 的指针 fmt.Println(*p) // 输出 10,通过指针解引用• &a 表示获取变量 a 的地址 p 表示…...
