【Linux】之进程间通信

0x00.概述

本文将基于linux系统介绍进程间通信的几种方式,包括匿名管道,命名管道,systemV的共享内存等,全是干货,无废话

0x01.匿名管道

匿名管道: 通过调用 pipe 函数创建的,它在内存中创建一个缓冲区,用于父子进程之间的通信。这个缓冲区通常是在内核的地址空间中分配的,而不是在文件系统中创建文件。因此,数据通过这个内存缓冲区进行传递,而不涉及真实的文件。匿名管道主要用于相关的父子进程之间的通信。

1.代码实现

#include <unistd.h>
#include <stdio.h>int main() {int pipefd[2];pipe(pipefd);pid_t child_pid = fork();if (child_pid == -1) {perror("fork");return 1;}if (child_pid > 0) {// Parent Processclose(pipefd[0]);  // 关闭读取端// 向管道写入数据const char *message = "Hello, Pipe!";write(pipefd[1], message, 13);close(pipefd[1]);  // 关闭写入端} else {// Child Processclose(pipefd[1]);  // 关闭写入端// 从管道读取数据char buffer[50];read(pipefd[0], buffer, sizeof(buffer));printf("Child Process: Received message: %s\n", buffer);close(pipefd[0]);  // 关闭读取端}return 0;
}

2.代码讲解

创建时pipe接收一个输出型参数,创建成功返回fd[0]和fd[1],分别对应管道的读和写端,子进程写父进程读,很好理解。

0x02.命名管道

命名管道: 通过调用 mkfifo 函数创建的,它在文件系统中创建一个特殊类型的文件。当进程使用命名管道进行通信时,数据通过文件系统的路径来传递。尽管文件系统中有一个相关的文件,但实际上,数据仍然是通过内存缓冲区传递的。但与匿名管道不同,命名管道提供了一个在文件系统中可见的标识符,允许独立的进程通过文件路径来访问这个管道

1.代码实现

#include <fcntl.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <unistd.h>int main() {const char *fifoPath = "/tmp/myfifo";// 创建命名管道mkfifo(fifoPath, 0666);// 创建子进程pid_t child_pid = fork();if (child_pid == -1) {perror("fork");return 1;}if (child_pid == 0) {// 子进程写入数据到命名管道int fd = open(fifoPath, O_WRONLY);const char *message = "Hello, FIFO!";write(fd, message, strlen(message));close(fd);} else {// 父进程读取数据从命名管道int fd = open(fifoPath, O_RDONLY);char buffer[100];read(fd, buffer, sizeof(buffer));printf("Parent Process: Received message: %s\n", buffer);close(fd);// 等待子进程结束wait(NULL);// 删除命名管道unlink(fifoPath);}return 0;
}

2代码讲解

int mkfifo(const char *pathname, mode_t mode)

总结:命名管道就是在磁盘上中创建了一个特殊的文件,这个文件可以被打开,但是打开后不会将内存中的数据刷新到磁盘。在磁盘上就有了路径,而路径是唯一的,所以双方就可以通过文件的路径来看到同一份资源,即管道文件。

0x03管道总结

1.管道是用来进行具有血缘关系的进程进行进程间通信 (常用于父子间通信)

2.管道具有通过让进程间协同,提供了访问控制(父子进程会相互协调进行读写操作)

3.管道提供的是面向字节流式的通信服务 --- 面向字节流 --- 通过定制协议实现(父进程多次写入,子进程一次性读取)

4.管道是基于文件的,文件的生命周期是随进程的,即管道的生命周期也随进程的!(数据通过内存缓冲区传递)

5.管道是单向通信的,就是半双工通信的一种特殊方式.(一边写完另一边才能读,类似对讲坤)

0x04.SystemV

1.原理图

2.理解

1.当共享内存创建出来后,通过系统调用挂接到对应的进程当中,操作系统会给进程分配一个mm_struct上的虚拟地址空间(在堆栈之间的共享代码区),通过页表建立与物理内存的映射,从而实现对共享内存的访问

2.共享内存块不属于某个进程,而属于操作系统。

3不同于pipe和fifo通过read,write来进行通信,共享内存属于用户空间,可以直接进行内存级的读和写。

3.实现

实现共享内存间通信分为以下几步:创建共享内存,将进程挂接到共享内存,使用共享内存,分离进程与共享内存,删除共享内存

先引入头文件

创建(create)

shmget()

第一个参数指定相同的key,调用一个类似哈希的算法ftok,求出一个相同的值

第二个参数指定共享内存的大小,一般是4096字节(页的整数倍)

第三个参数:设置选项后还可以加权限,一般是0666

1.IPC_CREATE:创建共享内存,如果底层已经存在,则获取并返回;如果不存在,则创建共享内存然后再返回,

 2.IPC_EXCL:单独使用它没有意义,一般和IPC_CREATE合起来使用,见下:

 3.IPC_CREATE | IPC_EXCL:如果底层不存在,则创建共享内存并返回;如果底层存在,则出错返回。言外之意,如果返回成功,那么一定是一个全新的内存块!

ftok()

一般用项目所在路径名和工程编号生成一个随机值

挂接(attach)

shmat()

函数接受三个参数:

shmid:共享内存段的标识符(ID),即通过调用 shmget() 函数创建共享内存时返回的 shmid。表示你想挂接哪一个共享内存。

shmaddr:共享内存段连接到进程地址空间的首地址。通常将其设置为 NULL,指示系统选择适当的地址。如果想要指定特定的地址,可以传递一个非空的地址值。但不建议这样使用。

shmflg:标志参数,用于指定连接共享内存的选项。常用的选项有:

SHM_RDONLY:以只读方式连接共享内存,不允许写入。
SHM_RND:将 shmaddr 参数忽略,系统选择一个地址以进行连接。

char* shmaddr = (char*)shmat(shmid,nullptr,SHM_RDONLY);

一般需要强转为我们需要的类型 

使用(use)

分离(detach)

shmdt()

成功返回0,失败返回-1 

删除(remove)

手动删除

在终端输入ipcs -m 查看共享内存使用情况

输入ipcrm -m shmid 删除共享内存

代码删除(shmctl)

shmid:共享内存段的标识符(ID),即通过调用 shmget() 函数创建共享内存时返回的 shmid。

cmd:控制命令,用于指定要执行的操作类型。可以使用以下命令之一:

IPC_STAT:获取共享内存段的状态信息,将结果存储在 buf 参数指向的 struct shmid_ds 结构体中。
IPC_SET:设置共享内存段的状态信息,使用 buf 参数中提供的值。
IPC_RMID:删除共享内存段,将其标记为删除状态,并在释放最后一个进程的附加段之后销毁。
buf:一个指向 struct shmid_ds 结构体的指针,用于传递或接收共享内存段的状态信息。
 

    int n = shmctl(shmid,IPC_RMID,nullptr);

 以上就是全部内容,能力有限,如果觉得对你有帮助,请点赞支持一下吧

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

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

相关文章

c++ 常用的一些宏定义

#include<iostream> #include <windows.h> #include <string> using namespace std;#define Conn(x,y) x##y //表示x连接y #define tochar(x) #x //给x加上单引号&#xff0c;结果返回是一个const char #define tostring(x) #x //给x加双引号 返回char co…

【毕业设计之Android系列】智能家居远程控制系统设计

智能家居远程控制系统设计 摘 要 该系统是一种基于Android平台的应用程序&#xff0c;可以通过网络连接实现对家居设备的远程控制。其主要功能包括家居设备的开关控制、温度调节、音乐播放、安防监控等。系统的设计需要考虑硬件、软件、数据传输、安全性和扩展性等因素&#xf…

Python基本语法及高级特性总结

1. Python基本语法 1.1 变量和数据类型 在Python中&#xff0c;变量不需要预先声明&#xff0c;可以直接赋值。Python是一种动态类型语言&#xff0c;变量的类型会根据赋值的对象自动确定。例如&#xff1a; a 10 # a是整数类型变量 b 3.14 # b是浮点数类型变量 c …

基于OHTPPS实现网站HTTPS访问

前言 笔者近期为网站配置HTTPS的域名&#xff0c;查找了大量方案&#xff0c;最近寻得一个不错的解决方式&#xff0c;通过OHTTPS获取免费的证书并部署到阿里云服务器上。 步骤 到OHTTPS官网注册账号 官方地址如下&#xff0c;读者可以先行到官网注册一下账号&#xff0c;笔…

第三十四课 电商控制台商品订单详情的整合

增删改查四个接口统一的规范 有5个接口 Add增 Delete 删除 Update 更新 查 按id查某个商品 findOne 查询所有 findAll 实现类实现5个接口 反射技术&#xff0c;反射到java bean当中的每一个属性。 Class.forName() 获取属性方法:getDeclaredFields() 构建增 删 查…

基于级联式逆残差网络的遥感图像轻量目标检测算法

源自&#xff1a;电子学报 作者&#xff1a;陈立 张帆 郭威 黄赟 李继中 “人工智能技术与咨询” 发布 摘 要 遥感场景下的高实时目标检测任务具有重要的研究价值与应用意义. 针对当前遥感图像目标检测模型由于目标多角度、排列密集以及背景复杂从而导致检测速度慢的…

Science Robotics封面文章:瑞士洛桑联邦理工学院研制仿生鳄鱼和仿生巨蜥机器人,走进非洲尼罗河

动物表现出多种多样的形态和大小&#xff0c;通常与它们所处的介质有关。它们可以游泳、爬行、行走、奔跑、跳跃、飞行和滑翔等。进化使它们复杂而有效地结合不同类型的运动来逃避捕食者、交配或寻找食物 。作为科学家去研究如此丰富的动物运动&#xff0c;可以了解自然界的一些…

外汇天眼:ACY Securities口碑爆炸疯狂滑点,你中枪了吗?

都说判断一个平台是否值得信赖投资&#xff0c;除了看它的监管牌照、创建年限&#xff0c;就是看它的口碑、声誉怎么样&#xff0c;因为即使平台拥有了正规的监管牌照、平台创立年限久远&#xff0c;同样会存在很多交易安全隐患&#xff0c;特别是平台出现大量客诉却一直不正面…

ubuntu 20.04 安装与切换多个版本cmake,安装多个版本gcc

1.安装多版本cmake 1)查看当前系统自带cmake版本及安装位置&#xff1a; ~$: cmake --version 如&#xff1a; cmake version 3.16.3 ~$: which cmake 如&#xff1a; /opt/cmake/cmake-3.16.3 2)下载对应的cmake&#xff0c;如&#xff1a; https://cmake.org/files/…

在vue3代码中,进行if判断的时候,使用值的时候忘记使用.value而导致的问题

问: 回答: 所以,我的代码中进行isAndroid的值的判断的时候,判断它是否是false的时候,需要加上isAndroid.value才能获取到,否则获取不到, 然而写法错误,却还是进入了安卓的判断, 问: 回答:

vue配置path路径别名

// vue.config.js const path require(path);//引入path模块 function resolve(dir) {return path.join(__dirname, dir) }默认代表src configureWebpack: {resolve: {extensions: [.js, .vue, .json],alias: {: resolve(src),~: process.cwd(),public: resolve(public),compo…

Chart 9 Adreno GPU的 OpenCL 扩展

文章目录 前言9.1 OS-dependent vendor extensions9.1.1 Performance hint (cl_qcom_perf_hint)9.1.2 Priority hint for context creation (cl_qcom_priority_hint)9.1.3 Recordable command queue (cl_qcom_recordable_queues)9.1.4 cl_qcom_protected_context9.1.5 cl_qcom_…

深入理解网络 I/O 多路复用:Epoll

&#x1f52d; 嗨&#xff0c;您好 &#x1f44b; 我是 vnjohn&#xff0c;在互联网企业担任 Java 开发&#xff0c;CSDN 优质创作者 &#x1f4d6; 推荐专栏&#xff1a;Spring、MySQL、Nacos、Java&#xff0c;后续其他专栏会持续优化更新迭代 &#x1f332;文章所在专栏&…

Odoo:行业领先的免费开源供应链管理系统

先进且开源的供应链管理系统和全球供应链协作优化方案 为满足复杂的供应链和库存管理要求&#xff0c;如今绝大多数企业都不得不部署多个供应链管理软件和库存管理系统软件。如何利用一个库存管理与供应链管理软件&#xff0c;跨地区、跨时区地管理现代供应链&#xff1f;Odoo…

Cocos Creator:坐标系

Cocos Creator&#xff1a;坐标系 坐标系节点位置坐标转换v3.8 实现原理&#xff08;不想了解可以直接跳过&#xff09;简单示例&#xff1a;&#xff08;干货or解决方案在这里&#xff01;&#xff09; 锚点缩放和旋转 总结心得 在 Cocos Creator 3.8 中&#xff0c;节点坐标系…

使用入耳耳机对耳朵有损害吗?入耳耳机和骨传导耳机哪款更值得入手?

由于入耳式耳机的传声原理&#xff0c;长时间使用是会对耳朵造成损害的&#xff0c;骨传导耳机相比与入耳耳机&#xff0c;不用入耳佩戴&#xff0c;还能在一定程度上保护听力&#xff0c;所以骨传导耳机更值得入手。 一、入耳耳机和骨传导耳机有什么不同 人的听觉系统分为搜…

lammps编译(2Aug2023、intel2020、rtx4070ti)

说明&#xff1a; [rootnode101 ~]# cat /etc/redhat-release CentOS Linux release 7.9.2009 (Core) [rootnode101 ~]# gcc -v Using built-in specs. COLLECT_GCCgcc COLLECT_LTO_WRAPPER/usr/libexec/gcc/x86_64-redhat-linux/4.8.5/lto-wrapper Target: x86_64-redhat-lin…

修复漏洞:Diffie-Hellman Key Agreement Protocol 资源管理错误漏洞(CVE-2002-20001)

1、背景 在安全检测流程中&#xff0c;发现爆出这个漏洞 2、修复方案 echo "kexalgorithms curve25519-sha256,curve25519-sha256libssh.org,ecdh-sha2-nistp256,ecdh-sha2-nistp384,ecdh-sha2-nistp521" >> /etc/ssh/sshd_configsystemctl restart sshd

Vmd+lstm代码详解 完整代码数据可直接运行

项目视频讲解:Vmd+lstm时间序列预测分类回归预测代码详解 完整代码可直接运行_哔哩哔哩_bilibili 项目演示效果: 代码详解: # -*- coding: utf-8 -*- # 导入库pip install openpyxl -i https://pypi.tuna.tsinghua.edu.cn/simple import pandas as pd import numpy as np fr…