Linux之进程间通信

1.进程间通信的目的
数据传输:一个进程需要将它的数据发送给另一个进程
资源共享:多个进程之间共享同样的资源。
通知事件:一个进程需要向另一个或一组进程发送消息,通知它(它们)发生了某种事件(如进程终止时要通知父进程)。
进程控制:有些进程希望完全控制另一个进程的执行(如 Debug 进程),此时控制进程希望能够拦截另一个进程的所有陷入和异常,并能够及时知道它的状态改变。

进程间通信的本质:让不同的进程看到同一份“资源”。 

2.进程间通信分类
管道
匿名管道 pipe
命名管道
System V IPC
System V 消息队列
System V 共享内存
System V 信号量
POSIX IPC
消息队列
共享内存
信号量
互斥量
条件变量
读写锁

 下面只详细介绍匿名管道,命名管道,System V共享内存。

管道

管道是单向通信的,管道是基于文件的,生命周期随进程

管道提供的是面向“流”式通信的,管道提供了访问控制。

3.匿名管道

fd :文件描述符数组 , 其中 fd[0] 表示读端 , fd[1] 表示写端 (可以把0理解成嘴巴(读),把1理解成笔(写))
返回值 : 成功返回 0 ,失败返回错误代码

匿名管道原理图 

匿名管道是让具有“血缘关系”的进程进行通信的。

创建完匿名管道之后,让父进程关闭"读",让子进程关闭“写”,这样就实现了“一个读,一个写”。

父子进程通过匿名管道进行通信,通信的内容没必要进行刷盘(持久化)。

当管道内没有数据,read会阻塞

当管道被写满,write会阻塞

当写端fd关闭,read返回0

当读端fd关闭,write操作会产生SIGPIPE信号,进而导致write退出

当要写入的数据量大于PIPE_BUF时,linux将不能保证写入的原子性

当要写入的数据量不大于PIPE_BUF时,linux能保证写入的原子性

4.命名管道

匿名管道的限制条件之一是具有“血缘关系”的进程之间进行通信,要想两个不相关的进程能进行通信 ,可以使用FIFO文件,即命名管道。

指明要在哪个路径下创建名为XXX的文件,并指明文件对应的权限,通过调用mkfifo创建该文件。

命名管道原理图

由于是在磁盘上创建有名字文件,这点就是和“匿名管道”的区别。

当然,该文件被加载到内存后,进程可以通过指定路径和指定文件名找到该文件,通过该文件进行进程间通信的内容,也不必刷新到磁盘中。

5.System V共享内存

System V共享内存原理图

System V共享内存进行通信比管道快,是因为数据拷贝次数少。

共享内存有关的函数
ftok

该函数是通过指定路径下的文件名,以及一个整数,系统来创建一个随机的key_t类型的值。

通过调用该函数,让不同的进程能创建出相同的key_t 类型的值(即为让不同进程看到同一份“资源”做铺垫)。

shmget

功能:用来创建共享内存

第一个参数是ftok函数创建的随机值,第二个参数是共享内存的大小(建议设置为4096的整数倍),第三个参数如果设置为IPC_CREAT(如果存在,则获取之,如果不存在,则创建),如果设置为IPC_CREAT  |   IPC_EXCL (如果不存在,则创建,如果存在,则出错返回)

返回值:成功返回一个非负整数,即该共享内存段的标识码;失败返回 -1
shmat

功能:建立共享内存段到进程地址空间之间的映射
参数
shmid: 共享内存标识
shmaddr:指定连接的地址
shmflg:它的两个可能取值是SHM_RND和SHM_RDONLY
返回值:成功返回一个指针,指向共享内存第一个节;失败返回-1
shmdt

功能:将共享内存段与当前进程之间的映射去掉
参数
shmaddr: 由shmat所返回的指针
返回值:成功返回0;失败返回-1
注意:将共享内存段与当前进程脱离不等于删除共享内存段
shmctl

功能:用于控制共享内存
参数
shmid:由shmget返回的共享内存标识码
cmd:将要采取的动作,其中填写  IPC_RMID  用来删除共享内存
buf:指向一个保存着共享内存的模式状态和访问权限的数据结构
返回值:成功返回0;失败返回-1

其中,struct shmid_ds的结果如下: 

 

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

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

相关文章

Rabbit简单模式理解

简单模式 我们以最普通的方式去理解&#xff0c;并没有整合Springboot的那种 这是最简单的模式&#xff0c;一个生产者&#xff0c;一个消费者&#xff0c;一个队列 测试 1、 导包&#xff0c;没整合&#xff0c;不需要编写配置 2、需要生产者消费者 导包 <dependency…

【Spring】通过Spring收集自定义注解标识的方法

文章目录 前言1. 声明注解2. 使用 Spring 的工厂拓展3. 收集策略4. 完整的代码后记 前言 需求&#xff1a; 用key找到对应的方法实现。使用注解的形式增量开发。 MyComponent public class Sample1 {MyMethod(key "key1")public String test2() {return "She…

【SpringCloud】Eureka注册中心

目 录 一.Eureka的结构和作用二.搭建 eureka-server1. 创建 eureka-server 服务2. 引入 eureka 依赖3. 编写启动类4. 编写配置文件5. 启动服务 三.服务注册1. 引入依赖2. 配置文件3. 启动多个user-service实例 四.服务发现1. 引入依赖2. 配置文件3. 服务拉取和负载均衡 总结 假…

Optimizer神经网络中各种优化器介绍

1. SGD 1.1 batch-GD 每次更新使用全部的样本&#xff0c;注意会对所有的样本取均值&#xff0c;这样每次更新的速度慢。计算量大。 1.2 SGD 每次随机取一个样本。这样更新速度更快。SGD算法在于每次只去拟合一个训练样本&#xff0c;这使得在梯度下降过程中不需去用所有训…

阿里云通用算力型u1云服务器配置性能评测及价格参考

阿里云服务器u1是通用算力型云服务器&#xff0c;CPU采用2.5 GHz主频的Intel(R) Xeon(R) Platinum处理器&#xff0c;ECS通用算力型u1云服务器不适用于游戏和高频交易等需要极致性能的应用场景及对业务性能一致性有强诉求的应用场景(比如业务HA场景主备机需要性能一致)&#xf…

C++经典面试题目(十六)

1、什么是类的构造函数&#xff1f;它有什么作用&#xff1f; 类的构造函数是一种特殊的成员函数&#xff0c;用于初始化类的对象。它在对象被创建时自动调用&#xff0c;可以用于执行对象的初始化工作&#xff0c;如分配内存、初始化成员变量等。构造函数的作用在于确保对象在…

002 HTML元素

文章目录 HTML的元素元素的属性 注释快捷键根元素head元素meta元素 body元素h元素p元素img元素src属性alt属性 路径分隔符a元素href属性target属性锚点链接 iframe元素div与span不常用元素HTML全局属性字符实体URL和URISEO字符编码 官方文档:https://www.w3.org/TR/ HTML的元素…

【数据结构】括号匹配问题你学会了吗?来刷刷题检验一下吧!!!

栈在括号问题中的应用 导言一、有效的括号——栈、字符串——简单1.1 题目要求与分析1.2 代码实现 二、 最长有效括号——栈、字符串、动态规划——困难2.1 题目要求与分析2.2 问题解析2.2.1 如何计算有效括号的个数2.2.2 如何记录了连续括号的长度2.2.3 如何寻找最长的子串 2.…

STM32 GPIO输入检测——按键

前言 在嵌入式系统开发中&#xff0c;对GPIO输入进行检测是一项常见且关键的任务。STM32微控制器作为一款功能强大的处理器&#xff0c;具有丰富的GPIO功能&#xff0c;可以轻松实现对外部信号的检测和处理。在本文中&#xff0c;我们将深入探讨如何在STM32微控制器上进行GPIO…

二十四种设计模式与六大设计原则(三):【装饰模式、迭代器模式、组合模式、观察者模式、责任链模式、访问者模式】的定义、举例说明、核心思想、适用场景和优缺点

接上次博客&#xff1a;二十四种设计模式与六大设计原则&#xff08;二&#xff09;&#xff1a;【门面模式、适配器模式、模板方法模式、建造者模式、桥梁模式、命令模式】的定义、举例说明、核心思想、适用场景和优缺点-CSDN博客 目录 装饰模式【Decorator Pattern】 定义…

linux redis 快速安装

选择合适的版本 以下是在Linux系统上安装Redis的步骤&#xff1a; 1、下载Redis&#xff1a; wget http://download.redis.io/releases/redis-7.2.0.tar.gz 2、解压缩Redis&#xff1a; tar xzf redis-7.2.0.tar.gz 3、编译Redis&#xff1a; cd redis-7.2.0 make 4、…

C语言——内存函数

前言&#xff1a; C语言中除了字符串函数和字符函数外&#xff0c;还有一些函数可以直接对内存进行操作&#xff0c;这些函数被称为内存函数&#xff0c;这些函数与字符串函数都属于<string.h>这个头文件中。 一.memcpy&#xff08;&#xff09;函数 memcpy是C语言中的…

维修贝加莱4PP420.1043-B5触摸屏Power Panel 400工业电脑液晶

深圳捷达工控维修为贝加莱、HMI 显示电源面板 400 4PP420.1043-B5 提供专业电子维修。在 深圳捷达工控维修&#xff0c;我们拥有及时且经济高效地维修 B&R 、HMI Display Power Panel 400 4PP420.1043-B5 的经验。我们为发送给我们工厂维修的贝加莱 HMI 显示面板 400 4PP42…

【智能算法】霜冰优化算法(RIME)原理及实现

目录 1.背景2.算法原理2.1算法思想2.2算法过程 3.结果展示4.参考文献 1.背景 2023年&#xff0c;H Su等人受到自然界霜冰生长机制启发&#xff0c;提出了霜冰优化算法&#xff08;Rime Optimization Algorithm, RIME&#xff09;。 2.算法原理 2.1算法思想 RIME模拟软霜颗粒…

css去除滑动框

css去除滑动框 要在CSS中去除滑动条&#xff0c;可以使用overflow属性。如果你想要在特定的元素上去除滑动条&#xff0c;可以将该元素的overflow属性设置为hidden&#xff0c;这样内容如果超出了元素的尺寸&#xff0c;就不会显示滑动条。 例如&#xff0c;如果你想要在一个…

【Laravel】06 数据库迁移工具migration

【Laravel】06 数据库迁移工具migration 1.migration文件目录2. 举例 1.migration文件目录 2. 举例 (base) ➜ example-app php artisan migrate Migration table created successfully. Migrating: 2014_10_12_000000_create_users_table Migrated: 2014_10_12_000000_crea…

QT(6.5) cmake构建C++编程,c++与python进行通信(命名管道)

QT(6.5) cmake构建C编程&#xff0c;c与python进行通信&#xff08;命名管道&#xff09; 首先&#xff0c;c端编写命名管导通信代码 #include <QDebug> #include <windows.h>bool fifp_cpp(){// 创建命名管道&#xff08;用于读写&#xff09;HANDLE hPipe;hPip…

HTTP/1.1、HTTP/2、HTTP/3 演变(计算机网络)

HTTP/1.1 相比 HTTP/1.0 提高了什么性能&#xff1f; HTTP/1.1 相比 HTTP/1.0 性能上的改进&#xff1a; 使用长连接改善了短连接造成的性能开销。支持管道网络传输&#xff0c;只要第一个请求发出去了&#xff0c;不必等其回来&#xff0c;就可以发第二个请求出去&#xff0c…

0基础学习Mybatis系列数据库操作框架——最小Demo

大纲 数据库Mybatis目录结构配置代码 代码/配置结构配置结构依赖库配置SQL配置Mybatis配置数据库配置SQL映射配置 完整配置 代码结构映射类Mybatis逻辑从 XML 中构建 SqlSessionFactory从 SqlSessionFactory 中获取 SqlSession通过mapper中的namespace和id执行SQL 完整逻辑和代…

nginx的https与动态负载均衡

nginx的https 证书可以根据你的域名和服务器服务商去进行签发 , 比如 : 阿里云 腾讯云 百度云 华为云等 这里使用的是腾讯云 : 下载证书 : 选择 nginx: 下载之后传递到服务器上。 下面开始配置nginx的https: 1. 解压下载的证书包 cd /etc/ssl unzip xxcc.dwa_nginx.zip mv…