进程通信——管道

什么是进程通信?

进程通信是实现进程间传递数据信息的机制。要实现数据信息传递就要进程间共享资源——内存空间。那么是哪块内存空间呢?进程间是相互独立的,一个进程不可能访问其他进程的内存空间,那么这块空间只能由操作系统提供。进程通信的方式有多种,管道就是一种。

管道是一种最简单的通信机制,管道分为匿名管道和命名管道。匿名管道通常用于父子进程之间。命名管道可实现任意两个进程通信。

匿名管道

原理

父进程打开管道文件流(读写两个流),分配描述符到文件描述符表。两个新的文件描述符分别指向管道的读端和写端。父进程创建子进程时,子进程的文件描述符表和父进程指向相同。父子进程指向的文件流都是共享的。

父子进程通信时,如果子进程写,父进程读,子进程关闭pipe_r,父进程关闭pipe_w;如果子进程读,父进程写,子进程关闭pipe_w,父进程关闭pipe_r。

使用样例

pipefd是一个输出型参数,pipefd[0] 表示的是读端的文件描述符,pipefd[1]表示的是写端文件描述符

创建管道->创建子进程->子进程关闭读端,写;父进程关闭写端,读->父进程等待子进程 

#include <iostream>
#include <unistd.h>
#include <cstdlib>
#include <sys/types.h>
#include <sys/wait.h>using namespace std;
void Write(int fd)
{char buffer[1024] = {0};pid_t id = getpid();int n = 0;string s = "I am child";while(1){snprintf(buffer,sizeof(buffer),"%s-%d-%d",s.c_str(),id,n);n++;write(fd,buffer,sizeof(buffer));sleep(1);if(n == 5) break;}
}void Read(int fd)
{char buffer[1024] = {0};while(1){ssize_t s = read(fd,buffer,sizeof(buffer));if(s > 0){cout << buffer << endl;}else if(s == 0){cout << "read ending" << endl;break;}else{cout << "read fail" << endl;}}
}int main()
{int pipefd[2] = {0};pipe(pipefd);pid_t id = fork();if(id < 0) return -1;if(id == 0){//childclose(pipefd[0]);//关闭读端Write(pipefd[1]);//close(pipefd[1]);exit(0);}//fatherclose(pipefd[1]);//关闭写端Read(pipefd[0]);pid_t ret = waitpid(id,nullptr,0);if(ret==id) cout << "wait success" << endl;else cout << "wait fail" << endl;//close(pipefd[0]);return 0;
}

命名管道

命名管道原理和匿名管道一样,区别就是命名管道会创建一个管道文件,两个进程分别对文件读写就可以了

使用样例

创建管道文件

 

销毁管道文件

 

 

//communicate.hpp 创建销毁管道进行封装
#include <iostream>
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
#include <errno.h>
#include <unistd.h>
#include <string.h>class Init
{
public:Init(){int n = mkfifo("./myfifo", 0777);if (n == -1){perror("fifo:");exit(-1);}}~Init(){int n = unlink("./myfifo");if(n == -1){perror("unlink:");exit(-1);}}
};//sever.cpp 服务器负责维护管道,读客户端数据
#include "communicate.hpp"
using namespace std;
int main()
{// 创建管道Init init;// 打开管道int fd = open("./myfifo", O_RDONLY);if (fd == -1){cout << strerror(errno) << endl;return -1;}// 开始通信while (1){char buffer[1024] = {0};ssize_t ret = read(fd, buffer, sizeof(buffer));if (ret > 0){cout << "sever get inf:" << buffer << endl;}else if (ret == 0){cout << "client quit, sever quit too" << endl;break;}elsebreak;}// 结束通信close(fd);
}//client.cpp 客户端负责向服务器写数据
#include "communicate.hpp"using namespace std;int main()
{//打开管道int fd = open("./myfifo", O_WRONLY);if(fd < 0){cout << strerror(errno) << endl;return -1;}//进行通信while(1){string ord;cout << "Input:";getline(cin, ord);write(fd, ord.c_str(), ord.size());}close(fd);return 0;
}

管道特征

  • 只有具有血缘关系的进程可以匿名管道通信

因为只有血缘关系的进程的可以指向同一个匿名管道,达成资源(内存空间)共享,这是通信的前提

  • 管道只能单向通信
  • 通信的进程会进行协同,同步与互斥,为了保证管道文件数据的安全

例如上面的样例:写端每写一次都会等待1s,写端没有写完时,读端会等待进行协同

  • 管道是面向字节流的

管道以字节为单位传输数据,而不是以消息或记录为单位。这意味着数据在传输过程中没有特定的结构或边界,发送方可以连续写入任意数量的字节,接收方则按照字节顺序读取数据。

  • 管道是基于文件的,文件的生命周期是随进程的

管道会随着进程结束而关闭,例如基础IO流并不需要用户手动关闭。在上面的例子中,子进程是写端,没有close(pipdf[1])也不会有错误,同样的父进程是读端,没有close(pipdf[0])不会有错误,因为进程结束这个管道流会自动关闭。

管道的4种情况

  1. 读写端正常,管道为空,读端就要阻塞
  2. 读写端正常,管道为满,写端就要阻塞
  3. 写端关闭,读端正常,读端读到0,表明读到了管道文件的结尾
  4. 读端关闭,写端正常,写端会被异常终止

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/21525.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

什么是RPA自动化办公?

RPA自动化办公&#xff1a;提升效率的利器 如今&#xff0c;自动化办公已成为提升效率、减少错误、节省成本的关键手段。RPA&#xff08;机器人流程自动化&#xff0c;Robotic Process Automation&#xff09;作为其中的重要组成部分&#xff0c;正受到越来越多企业的青睐。那…

【全开源】简单商城系统源码(PC/UniAPP)

提供PC版本、UniAPP版本(高级授权)、支持多规格商品、优惠券、积分兑换、快递鸟电子面单、支持移动端样式、统计报表等 提供全部前后台无加密源代码、数据库离线部署。 构建您的在线商店的基石 一、引言&#xff1a;为什么选择简单商城系统源码&#xff1f; 在数字化时代&am…

【Spring Cloud Alibaba】初识Spring Cloud Alibaba

目录 回顾主流的微服务框架Spring Cloud 版本简介Spring Cloud以往的版本发布顺序排列如下&#xff1a; 由停更引发的"升级惨案"哪些Netflix组件被移除了&#xff1f; 替换方案服务注册中心&#xff1a;服务调用&#xff1a;负载均衡&#xff1a;服务降级&#xff1a…

Python—面向对象小解(6)-闭包、装饰器

一、闭包 在Python中&#xff0c;闭包&#xff08;closure&#xff09;是一个函数对象&#xff0c;即使在其词法作用域外被调用&#xff0c;它仍然能访问该作用域内的变量。闭包通过“捕获”周围作用域的变量&#xff0c;保持这些变量的状态&#xff0c;即使在外部函数已经返回…

干货分享 | TSMaster 中 Hex 文件编辑器使用详细教程

TSMaster 软件的 Hex 文件编辑器提供了文件处理的功能&#xff0c;这一特性让使用 TSMaster 软件的用户可以更便捷地对 Hex、bin、mot、s19 和 tsbinary 类型的文件进行处理。 本文重点讲述 TSMaster 中 Hex 文件编辑器的使用方法&#xff0c;该编辑器能实现将现有的 Hex、bin、…

@vue-office/excel 解决移动端预览excel文件触发软键盘

先直接上代码 不耽误大家时间 标明下插件库 非常感谢作者提供预览插件 vue-office/excel 只需要控制CSS :deep(.x-spreadsheet-overlayer) {.x-spreadsheet-selectors {display: none !important;} } :deep(.x-spreadsheet-bottombar) {li.active {user-select: none !import…

家政上门系统源码,家政上门预约服务系统开发涉及的主要功能

家政上门预约服务系统开发是指建立一个在线平台或应用程序&#xff0c;用于提供家政服务的预约和管理功能。该系统的目标是让用户能够方便地预约各种家政服务&#xff0c;如保洁、家庭护理、月嫂、家电维修等&#xff0c;并实现服务供应商管理和订单管理等功能。 以下是开发家政…

Windows API 速查

Windows API 函数大全 (推荐)&#xff1a;https://blog.csdn.net/xiao_yi_xiao/article/details/121604742Windows API 在线参考手册&#xff1a;http://www.office-cn.net/t/api/index.html?web.htmWindows 开发文档 (官方)&#xff1a;https://learn.microsoft.com/zh-cn/wi…

linux驱动学习(三)之uboot与内核编译

需要板子一起学习的可以这里购买&#xff08;含资料&#xff09;&#xff1a;点击跳转 GEC6818内核源码下载&#xff1a;点击跳转 一、环境配置 由于GEC6818对应是64位系统&#xff0c;虚拟机中的linux系统也要是64位&#xff0c;比如&#xff1a;ubuntu16.04.rar …

Bee 支持 与 mybatis-plus 混用吗?

Bee 支持 与 mybatis-plus 混用吗&#xff1f; 你是在什么场景下要混用呢? mybatis-plus是基于mybatis. 而Bee本身就是一个ORM框架了. Hibernate/MyBatis plus Sharding JDBC Jpa Spring data GraphQL App ORM (Android, 鸿蒙) Bee Bee支持的数据库 1.MySQL 2.Oracle 3.SQL…

elasticsearch的常规操作--增删改查和批量处理

1、_cat 查询 GET /_cat/nodes&#xff1a; 查看所有节点 GET /_cat/health&#xff1a; 查看es 健康状况 GET /_cat/master&#xff1a; 查看主节点 GET /_cat/indices&#xff1a;查看所有索引show databases; 2、索引一个文档&#xff08;保存&#xff09; 保存一个数据&…

某红书旋转滑块验证码分析与协议算法实现(高通过率)

文章目录 1. 写在前面2. 接口分析3. 验证轨迹4. 算法还原 【&#x1f3e0;作者主页】&#xff1a;吴秋霖 【&#x1f4bc;作者介绍】&#xff1a;擅长爬虫与JS加密逆向分析&#xff01;Python领域优质创作者、CSDN博客专家、阿里云博客专家、华为云享专家。一路走来长期坚守并致…

力扣SQL50 学生们参加各科测试的次数 查询 三表查询

Problem: 1280. 学生们参加各科测试的次数 &#x1f468;‍&#x1f3eb; 参考题解 join等价于inner join&#xff0c;不用关联条件的join等价于cross join Code select stu.student_id,stu.student_name, sub.subject_name,count(e.subject_name) attended_exams from Stud…

关于windosw打开安全中心空白的解决方案

关于windosw打开安全中心空白的解决方案 问题如下 问题如下 之后点击一片空白 解决方案如下 按下WINR&#xff0c;输入regedit回车找到路径&#xff1a;“HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\SecurityHealthService”&#xff0c;然后双击右边的“start”…

【最新鸿蒙应用开发】——关系型数据库简单上手(RDB)

关系型数据库&#xff08;RDB&#xff09; 关系型数据库&#xff08;Relational Database&#xff0c;RDB&#xff09;是一种基于关系模型来管理数据的数据库。关系型数据库基于SQLite组件提供了一套完整的对本地数据库进行管理的机制&#xff0c;对外提供了一系列的增、删、改…

【cocos sreator】判定多边形和多边形相交

核心代码&#xff1a; cc.Intersection.polygonPolygon(points2, points) 拖拽物品拖到多个目标位置判定&#xff0c;取最近的&#xff1a; getTargetItem(collider2: cc.PolygonCollider, touchPos: cc.Vec2, targetRoot: cc.Node) {let length 99999;let target null;//col…

windows 下编译 TessRact+leptonica 识别图片文字

目录 1、下载 2. 编译基础依赖库 1.1 zlib 1.2 jpegsr9f 1.3 lpng1643 1.4 libgif 3. 编译tifflib 4. 配置nasm到系统环境中 5. 编译 libjpeg-turbo 6 编译leptonica 7. 编译tesseract 8. 测试验证 1、下载 下载tesseract5.3.2 下载leptonica1.83.1 下载l…

1638. 统计只差一个字符的子串数目

题目 给你两个字符串 s 和 t&#xff0c;请找出 s 中的非空子串的数目&#xff0c;这些子串满足替换一个不同字符以后&#xff0c;是 t 串的子串。换言之&#xff0c;请你找到 s 和 t 串中恰好只有一个字符不同的子字符串对的数目。 一个子字符串是一个字符串中连续的字符。 …

【全开源】旅游门票预订系统(FastAdmin+ThinkPHP+Uniapp)

一款基于FastAdminThinkPHPUniapp开发的旅游门票预订系统&#xff0c;支持景点门票、导游产品便捷预订、美食打卡、景点分享、旅游笔记分享等综合系统&#xff0c;提供前后台无加密源码&#xff0c;支持私有化部署。 ​便捷你的每一次出行&#x1f30d; &#x1f31f; 轻松预订…

PMP中的各种图

单、双代号网络图 区别 内容 箭线图&#xff08;ADM&#xff09;-双 箭线活动 节点依赖关系 箭线图只能表示一种FS的关系 规划和控制项目活动进度的项目 &#xff08;建筑、软件&#xff09; 前导图&#xff08;PDM&#xff09;-单 节点代表活动 前导图法可以体现多种逻…