Linux 管道理解
一、什么是管道
1.1 unix中最古老的进程间通信
1.2 一个进程链接到另一个进程的数据流称为“管道”:
图解:

二、管道通信的原理
2.1当我们创建一个进程然后打开一个文件的时候
会经过以下步骤:
①首先要描述这个进程,为这个进程创建一个task_struct的结构体对象;
②然后通过task_struct结构体里的文件描述符表指针找到这张文件描述符表;
③通过文件描述符表里的指针指向所对应打开的文件;
④文件里包含有inode文件属性、file_operators读写方法、缓冲区;
这时候就可以调用文件的读写方法对这个文件进行操作了!
图解:

2.2 当我们创建一个子进程的时候

此时子进程就能够看到父进程所看到的所有文件!!
进程通信的本质:让不同的进程看到统一份资源!
既然子进程能够看到父进程的内容了,那么父子进程之间怎么进行通信呢??
2.3 约定
想进行通讯父子进程间必须要有一个约定,要么规定父进程写入,子进程读取;或者父进程读取,子进程写入;
然而这样就行了吗?还没有,因为如果父进程是以读的方式打开的文件,子进程继承后也只能以读的方式操作这个文件而不能实现父写子读、父读子写,那怎么办呢?
2.4 方法
①父进程打开文件的时候以读文件打开一次文件,再以写方式打开一次文件(共打开两次同一文件);
②父进程fork子进程后,子进程继承父,并根据实际的场景,关闭父的读+子的写(实现父写子读)或者关闭父的写+子的读(实现父读子写)!
图解:

三、代码实现
3.1 用到的接口
①:建立管道接口
#include <unistd.h> //头文件
int pipe(int pipefd[2]); //返回值小于0表示失败,pipefd 输出型参数,意思传入一个数组把文件的文件描述符带出来让用户使用!!
记住:pipefd[0] :读下标 pipefd[1] :写下标
②:系统调用写接口
#include<unistd.h> //头文件
ssize_t write(int fd,void*buffer,size_t count);
//fd -> 写入一个被打开的文件的描述符
//buffer -> 作为缓冲区用来写入/读取文件
// count -> 写入的大小
//size_t 写入成功返回写入的字节数,写入失败返回-1
③:系统调用读接口
#include <unistd.h> //头文件
ssize_t read(int fd,void*buffer,size_t count);
//fd -> 被打开的文件的描述符(从哪读)
// buffer -> 读写缓冲区 (读到哪)
// count -> 读取的字节数
// ssize_t -> 读取成功返回读取的字节数,读取失败返回-1,读取到文件末尾返回0
④:fork()函数
#include <unistd.h> //头文件
#include <sys/types.h> //头文件
函数原型pid_t fork( void);(pid_t 是一个宏定义,其实质是int 被定义在#includesys/types.h>中)返回值:若成功调用一次则返回两个值,子进程返回0,父进程返回子进程ID;否则,出错返回-1
⑤:snprintf()函数
#include <stdio.h>//头文件
int snprintf(char* str,size_t size,const char*format,...);
//str -> 写到的位置
// size -> 写到的位置的大小
// format -> 格式字符串
// ... 列表
⑥:waitpid()函数
#include <sys/types.h>
#include <sys/wait.h>
pid_t waitpid(pid_t pid,int *status,int options);
3.2 linux下实现两个进程之间的管道通信
//testipc1.cpp
#include <unistd.h>
#include <cstdio>
#include <cstring>
#include <sys/wait.h>
#include <sys/types.h>
#include <iostream>
#define SIZE 1024
using namespace std;
void Write(int wfd)
{//写入内容char buffer[SIZE]={0};//缓冲区int number =0;//记录写入次数const char*message="hello linux!! i am child!!";while (true){//子不停写snprintf(buffer,sizeof(buffer),"%s - pid:%d -%d\n",message,getpid(),number++);write(wfd,buffer,strlen(buffer));sleep(2);//每隔两秒写}}
void Read(int rfd)
{char buffer[SIZE]={0};//缓冲区while(true){ssize_t redcount= read(rfd,buffer,sizeof(buffer));if(redcount){buffer[redcount]='\0';}cout<<buffer<<endl;}
}
int main()
{int pipefd[2];int retpipe=pipe(pipefd);//建立管道pid_t id=fork();//创建子进程if(id<0)return 1;//创建失败else if(id==0){//child//父读子写,子关闭读close(pipefd[0]);Write(pipefd[1]);exit(0);//子写完退出程序}else//farther//父读子写,父关闭写close(pipefd[1]);Read(pipefd[0]);pid_t retpid=(id,NULL,0);if(retpid<0)return 3;//等待失败return 0;
}
//makefile文件
testipc1:testipc1.cpp ##依赖目标:依赖文件g++ -o $@ $^ -std=c++11
.PHONY:clean
clean:rm -f testipc1
测试:

父进程成功读取子进程写入的内容!!
四、总结
4.1、管道的五大特征
①具有血缘关系的进程;
②父子进程会协同,同步与互斥,---保护管道文件的数据安全;
③管道只能单向通信;
④管道是面向字节流的;
⑤管道是基于文件的,而文件的生命周期是随进程的;
4.2、管道的几种情况
①读写端正常,管道如果为空,读端阻塞;
②读写正常,管道写满,写端阻塞;
③读端正常,写端关闭,读端会读到0;
相关文章:
Linux 管道理解
一、什么是管道 1.1 unix中最古老的进程间通信 1.2 一个进程链接到另一个进程的数据流称为“管道”: 图解: 二、管道通信的原理 2.1当我们创建一个进程然后打开一个文件的时候 会经过以下步骤: ①首先要描述这个进程,为这个…...
国产RK3568+FPGA以 “实时控制+高精度采集+灵活扩展” 为核心的解决方案
RK3568FPGA方案在工业领域应用的核心优势 一、实时性与低延迟控制 AMP架构与GPIO中断技术 通过非对称多处理架构(AMP)实现Linux与实时操作系统(RTOS/裸机)协同,主核负责调度,从核通过GPIO中断响应紧…...
Pycharm(十五)面向对象程序设计基础
目录 一、面向对象基本概述 class 类名: 属性(类似于定义变量) 行为(类似于定义函数,只不过第一个形参要写self) 二、self关键字介绍 三、在类内部调用类中的函数 四、属性的定义和调用 五、魔法方法init方法 六、魔法方法str和del方法 七、案例-减肥 一、…...
华三(H3C)与华为(Huawei)设备配置IPsec VPN的详细说明,涵盖配置流程、参数设置及常见问题处理
以下是针对华三(H3C)与华为(Huawei)设备配置IPsec VPN的详细说明,涵盖配置流程、参数设置及常见问题处理: 一、华三(H3C)设备IPsec VPN配置详解 1. 配置流程 华三IPsec VPN配置主要…...
【消息队列RocketMQ】四、RocketMQ 存储机制与性能优化
一、RocketMQ 存储机制详解 1.1 存储文件结构 RocketMQ 的存储文件主要分布在store目录下,该目录是在broker.conf配置文件中通过storePathRootDir参数指定的,默认路径为${user.home}/store 。主要包含以下几种关键文件类型: 1.1.1 Comm…...
结合地理数据处理
CSV 文件不仅可以存储表格数据,还可以与地理空间数据结合,实现更强大的地理处理功能。例如,你可以将 CSV 文件中的坐标数据转换为点要素类,然后进行空间分析。 示例:将 CSV 文件中的坐标数据转换为点要素类 假设我们有…...
店匠科技摘得 36 氪“2025 AI Partner 创新大奖”
全场景 AI 方案驱动跨境电商数智化跃迁 4 月 18 日,36 氪 2025 AI Partner 大会于上海盛大开幕。大会紧扣“Super App 来了”主题,全力探寻 AI 时代的全新变量,探索 AI 领域下一个超级应用的无限可能性。在此次大会上,跨境电商独立站 SaaS 平台店匠科技(Shoplazza)凭借“店匠跨…...
Joint communication and state sensing under logarithmic loss
摘要——我们研究一种基本的联合通信与感知设置,其中发射机希望向接收机传输一条消息,并同时通过广义反馈估计其信道状态。我们假设感知目标是获得状态的软估计(即概率分布),而非通常假设的点估计;并且我们…...
测试基础笔记第十天
提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 文章目录 一、查询语句1.基本查询2.条件查询3.模糊查询4.范围查询5.判断空 二、其他复杂查询1.排序2.聚合函数3.分组4.分页查询 一、查询语句 1.基本查询 – 需求1: 准备商…...
Geek强大的电脑卸载软件工具,免费下载
一款强大的卸载电脑软件工具,无需安装 免费下载...
Linux:41线程控制lesson29
1.线程的优点: • 创建⼀个新线程的代价要⽐创建⼀个新进程⼩得多 创建好线程只要调度就好了 • 与进程之间的切换相⽐,线程之间的切换需要操作系统做的⼯作要少很多 为什么? ◦ 最主要的区别是线程的切换虚拟内存空间依然是相同的&#x…...
基于Flask与Ngrok实现Pycharm本地项目公网访问:从零部署
目录 概要 1. 环境与前置条件 2. 安装与配置 Flask 2.1 创建虚拟环境 2.2 安装 Flask 3. 安装与配置 Ngrok 3.1 下载 Ngrok 3.2 注册并获取 Authtoken 4. 在 PyCharm 中创建 Flask 项目 5. 运行本地 Flask 服务 6. 启动 Ngrok 隧道并获取公网地址 7. 完整示例代码汇…...
Ai晚报20250423
Kortix 发布全球首个开源通用型 AI Agent——Suna,能像人类一样学习、推理和适应,通过自然对话帮助用户完成多种现实任务,支持浏览器自动化、文件管理等 20 个用户场景。腾讯混元大模型 AI 阅读助手“企鹅读伴”正式上线,为中小学…...
密码学货币混币器详解及python实现
目录 一、前言二、混币器概述2.1 混币器的工作原理2.2 关键特性三、数据生成与预处理四、系统架构与流程五、核心数学公式六、异步任务调度与 GPU 加速七、PyQt6 GUI 设计八、完整代码实现九、自查测试与总结十、展望摘要 本博客聚焦 “密码学货币混币器实现”,以 Python + P…...
HTMLCSS实现网页轮播图
网页中轮播图区域的实现与解析 在现代网页设计中,轮播图是一种常见且实用的元素,能够在有限的空间内展示多个内容,吸引用户的注意力。下面将对上述代码中轮播图区域的实现方式进行详细介绍。 一、HTML 结构 <div class"carousel-c…...
如何确定置信水平的最佳大小
在统计学中,置信水平的选择并不是一成不变的,而是根据具体的研究目的、样本量、数据类型以及行业标准等因素来确定的。然而,在大多数情况下,95%的置信水平是最常用的。 选择95%置信水平的原因 平衡可靠性与精确性: •…...
Java基础第21天-正则表达式
正则表达式是对字符串执行模式匹配的技术 如果想灵活的运用正则表达式,必须了解其中各种元字符的功能,元字符从功能上大致分为: 限定符选择匹配符分组组合和反向引用符特殊字符字符匹配符定位符 转义号\\:在我们使用正则表达式去检索某些特…...
Maven 项目中引入本地 JAR 包
在日常开发过程中,我们有时会遇到一些未上传到 Maven 中央仓库或公司私有仓库的 JAR 包,比如第三方提供的 SDK 或自己编译的库。这时候,我们就需要将这些 JAR 包手动引入到 Maven 项目中。本文将介绍两种常见方式:将 JAR 安装到本…...
CSGO 盲盒开箱系统技术实现深度解析
一、系统架构设计 (一)前后端分离架构 采用前后端分离模式,后端专注业务逻辑处理与数据管理,前端负责用户交互界面呈现。后端通过 RESTful API 与前端进行数据交互,这种架构能有效提高开发效率,便于团队分…...
JS通过GetCapabilities获取wms服务元数据信息并在SuperMap iClient3D for WebGL进行叠加显示
获取wms服务元数据信息并在三维webgl客户端进行叠加显示 <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width, initial-scale1.0"><tit…...
7N60-ASEMI无人机专用功率器件7N60
编辑:LL 7N60-ASEMI无人机专用功率器件7N60 型号:7N60 品牌:ASEMI 封装:TO-220F 最大漏源电流:7A 漏源击穿电压:600V 批号:最新 RDS(ON)Max:1.20Ω …...
Redis日常学习(一)
我的Redis学习笔记:从命令行到性能调优 Redis Redis(Remote Dictionary Server)本质上是一个基于内存的键值存储系统. 安装配置Redis的过程非常简单: # Ubuntu/Debian安装Redis sudo apt-get update sudo apt-get install red…...
Pytorch图像数据转为Tensor张量
PyTorch的所有模型(nn.Module)都只接受Tensor格式的输入,所以我们在使用图像数据集时,必须将图像转换为Tensor格式。PyTorch提供了torchvision.transforms模块来处理图像数据集。torchvision.transforms模块提供了一些常用的图像预…...
Java 加密与解密:从算法到应用的全面解析
Java 加密与解密:从算法到应用的全面解析 一、加密与解密技术概述 在当今数字化时代,数据安全至关重要。Java 加密与解密技术作为保障数据安全的关键手段,被广泛应用于各个领域。 加密是将明文数据通过特定算法转换为密文,使得…...
Java基础系列-HashMap源码解析2-AVL树
文章目录 AVL树左旋右旋左旋右旋的4种情况LL 型RR 型LR 型RL 型 实际插入时怎么判断是那种类型?插入时注意事项删除节点 AVL树 为避免BST树退化成链表的极端情况, AVL 树应运而生。 平衡因子取值(-1,0,1)…...
蓝桥杯 19. 最大比例
最大比例 原题目链接 题目描述 X 星球的某个大奖赛设了 M 级奖励。每个级别的奖金是一个正整数。 并且,相邻两个级别间的比例是一个固定值,也就是说:所有级别的奖金构成一个等比数列。 例如: 奖金数列为 16, 24, 36, 54&…...
前端加密介绍与实战
前端数据加密 文章目录 前端数据加密前端数据加密介绍为什么需要前端数据加密?前端数据加密的常见方式前端数据加密的实现场景:加密用户密码并发送到后端步骤 1:安装加密库步骤 2:实现加密逻辑步骤 3:后端解密 实战总结…...
Zookeeper是什么?基于zookeeper实现分布式锁
zookeeper听的很多,但实际在应用开发中用的不错,主要是作为中间件配合使用的,例如:Kafka。 了解zk首先需要知道它的数据结构,可以想象为树、文件夹目录。每个节点有基本的信息,例如:创建时间、…...
Kafka 主题设计与数据接入机制
一、前言:万物皆流,Kafka 是入口 在构建实时数仓时,Kafka 既是 数据流动的起点,也是后续流处理系统(如 Flink)赖以为生的数据源。 但“消息进来了” ≠ “你就能处理好了”——不合理的 Topic 设计、接入方…...
gem5-gpu教程05 内存建模
memory-modeling|Details on how memory is modeled in gem5-gpu gem5-gpu’s Memory Simulation gem5-gpu在很大程度上避开了GPGPU-Sim的单独功能模拟,而是使用了gem5的执行中执行模型。因此,当执行存储/加载时,内存会被更新/读取。没有单独的功能路径。(顺便说一句,这…...
