14-4-进程间通信-共享内存

news2024/11/13 17:52:57

之前学习了无名管道,命名管道,消息队列。

还剩下:共享内存,信号,信号量。

本章讨论的是共享内存。

一、共享内存的应用场景

A进程有自己的存储空间;

B进程也有自己的存储空间;

A进程和B进程不能进行数据交流;

但是在系统的内存中有1块公共内存;

此时,A进程和B进程依赖该公共内存可实现数据交流;

二、使用共享内存的思路

1.创建/打开 共享内存

2.映射

3.数据交换

4.释放共享内存

三、相关API

注意:共享内存的大小必须以MB对齐

https://editor.csdn.net/md/?articleId=129099839

1.创建1个共享内存

作用:创建一个共享内存 

参数:

        key:为共享内存的名字,一般是ftok的返回值。

        size:共享内存的大小,以page为单位,大小为4096的整数倍。

        shmflg:权限标志,常用两个IPC_CREAT和IPC_EXCL,一般后面还加一个权限,相当于文件的权限。

                                IPC_CREAT:创建一个共享内存返回,已存在打开返回

                                IPC_EXCL:配合着IPC_CREAT使用,共享内存已存在出错返回。

                                使用:IPC_CREAT | IPC_EXCL | 0666

返回值:

        成功返回一个非负整数,即共享内存的标识码,失败返回-1。

        为什么已经有一个key来标识共享内存,还需要一个返回值来标识共享内存?因为key是内核级别的,供内核标识,shmget返回值是用户级别的,供用户使用的。

 2.映射

作用:使创建的共享内存与调用该函数进程的进程地址空间参数关联。

参数:

        shmid:共享内存的标识,shmget的返回值。

        shmaddr:指定进程地址空间连接的地址。如果设置为null,默认让系统定要关联的地址。

        shmflg: 权限,常见有两个SHM_RDONLY(只读)和SHM_REMAP(重新映射一个进程地址空间没这样shmaddr不能为空)。设为0,系统默认。

 返回值:

        返回映射到进程地址空间共享区的开始地址。
————————————————
版权声明:本文为CSDN博主「两片空白」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/weixin_57023347/article/details/120307395

3.删除映射关系,释放地址空间

 作用:删除共享内存与进程地址空间的映射关系,将页表映射关系删除,释放进程地址空间。

参数:

        shmaddr:共享内存映射到进程地址空间的地址。shmat返回值。

返回值:

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

 4.控制共享内存

作用:用于控制共享内存

参数:        shmid:共享内存的标识

                   cmd:以什么方式来控制共享内存。IPC_RMID是释放共享内存

                   buf:指向一个共享内存的数据结构 。struct shmid_ds

返回值:成功返回0,失败返回-1。
————————————————
版权声明:本文为CSDN博主「两片空白」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/weixin_57023347/article/details/120307395

 5.shell指令查看共享内存

ipcs -m

 

四、编程实现共享内存

1.步骤

(1)生成键值;

(2)shmget();//创建共享内存,共享内存的大小是以MB为对齐单位的

(3)shmat();//映射

(4)在共享内存里做数据处理;比如进程A向共享内存写数据,过5秒进程B从共享内存读数据;

(5)shmdt();//卸载,,删除 映射关系

(6)shnctl();//关闭共享内存

2..代码实现

功能:进程A创建共享内存,映射,向共享内存里写入数据,几秒后删除映射关系,关闭共享内存;

进程B打开共享内存,从共享内存读取数据,关闭映射关系;

A.c

#include <stdio.h>
#include <sys/ipc.h>
#include <sys/shm.h>
#include <stdlib.h>
#include <string.h>
#include <unistd.h>
int main()
{
        int shmid;
        char *shmaddr;
        key_t key;
        key = ftok(".",1);

        shmid = shmget(key,1024*4,IPC_CREAT|0666);
        if(shmid == -1)
        {
                printf("shget failed\n");
                exit(-1);
        }

        shmaddr = shmat(shmid,0,0);
        printf("shmat ok\n");

        strcpy(shmaddr,"12345");
        sleep(3);
        shmdt(shmaddr);
        shmctl(shmid,IPC_RMID,0);
        printf("quit\n");

        return 0;
}

B.c

#include <stdio.h>
#include <sys/ipc.h>
#include <sys/shm.h>
#include <stdlib.h>
#include <string.h>
#include <unistd.h>
int main()
{
        int shmid;
        char *shmaddr;
        key_t key;
        key = ftok(".",1);

        shmid = shmget(key,1024*4,0);

        if(shmid == -1)
        {
                printf("shget failed\n");
                exit(-1);
        }

        shmaddr = shmat(shmid,0,0);
        printf("shmat ok\n");
        printf("data:%s\n",shmaddr);

        shmdt(shmaddr);
        printf("quit\n");

        return 0;
}
~   

运行结果:

 

 五,如何利用shell指令删除共享内存?

ipcrm -m xxxxxx(xxxxxx指共享内存的shmid)

六、实际应用中可能遇到的问题

如果有两个进程,进程A向共享内存写入数据后,进程B才从共享内存 读数据。那么不会出问题;

但是,如果进程A和进程B同时向共享内存写入数据,则会导致共享内存中的数据紊乱。

后面讲解“信号”时,会提出解决方法。

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

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

相关文章

使用物联网技术进行肥胖管理是可行的吗?

在物联网和可穿戴设备的帮助下&#xff0c;个人现在可以监测自己的健康指标&#xff0c;如心率、血糖水平和身体活动。这些个性化的见解帮助人们对自己的生活方式做出明智的决定&#xff0c;从而带来更好的体重管理结果。 利用物联网技术成功管理肥胖症 肥胖是一个全球性的健…

还在挣扎文件

由于在老式打印机里面每打下一行都要进行回车和换行&#xff0c;在windows系统里面也延续了这个惯例&#xff0c;但是c语言是只有换行&#xff0c;但是为了兼容&#xff0c;会自动进行转换&#xff1b;比如&#xff0c;它在写入文件的时候换行会自动转换为回车加换行&#xff0…

加强网络风险生命周期

当今业务环境中云原生应用程序的激增帮助组织简化了运营。 企业现在可以近乎实时地监控数据、与客户互动并分享见解&#xff0c;帮助他们克服曾经阻碍生产力的低效率问题。 然而&#xff0c;使用云也极大地扩展了企业可利用的攻击面。 CSPM、CWPP、CNAPP、SAST、SCA、IaC、D…

网络基础3【网络层、数据链路层】

目录 一.网络层 1.IP协议 &#xff08;1&#xff09;基本概念 &#xff08;2&#xff09;协议头格式 2.网段划分 3.特殊的IP地址 4.IP地址的数量限制 5.私有IP地址和公网IP地址 6.路由 二.数据链路层 1.以太网 2.以太网帧格式 3.MAC地址 4.对比MAC地址和IP地址 …

【图】邻接矩阵

图的存储结构分为邻接矩阵和邻接表两种&#xff0c;带权的图叫做网。 邻接矩阵 邻接矩阵适合边多的图 无向图 两个顶点之间的连线是双向的&#xff0c;一个一维数组存顶点&#xff0c;一个二维数组存边 若有边则值为1&#xff0c;反之为0 邻接矩阵需要知道点数、边数、一个二维…

ARM微处理器的指令集概述

ARM处理器是基于精简指令集计算机&#xff08;RISC&#xff09;原理设计的&#xff0c;指令集和相关译码机制较为简单。ARM微处理器的指令集是加载&#xff08;Load&#xff09;/存储&#xff08;Store&#xff09;型的&#xff0c;也即指令集仅能处理寄存器中的数据&#xff0…

【论文笔记】Attention和Visual Transformer

Attention和Visual Transformer Attention和Transformer为什么需要AttentionAttention机制Multi-head AttentionSelf Multi-head Attention&#xff0c;SMA TransformerVisual Transformer&#xff0c;ViT Attention和Transformer Attention机制在相当早的时间就已经被提出了&…

Word2vec原理+实战学习笔记(二)

来源&#xff1a;投稿 作者&#xff1a;阿克西 编辑&#xff1a;学姐 前篇&#xff1a;Word2vec原理实战学习笔记&#xff08;一&#xff09; 视频链接&#xff1a;https://ai.deepshare.net/detail/p_5ee62f90022ee_zFpnlHXA/6 5 对比模型&#xff08;论文Model Architectur…

锐捷(十七)锐捷单臂路由的配置

一 实验拓扑 二 实验需求 用单臂路由实现不同vlan间的通信&#xff0c;即要求vlan10的主机和vlan20的主机之间通过三层实现互访 三 实验分析 路由器的物理接口可以被划分成多个逻辑接口&#xff0c;这些被划分后的逻辑接口被形象的称为子接口。值得注意的是这些逻辑子接口不能…

Redis高级——键值对设计

1、Redis键值设计 1.1、优雅的key结构 Redis的Key虽然可以自定义&#xff0c;但最好遵循下面的几个最佳实践约定&#xff1a; 遵循基本格式&#xff1a;[业务名称]:[数据名]:[id]长度不超过44字节不包含特殊字符 例如&#xff1a;我们的登录业务&#xff0c;保存用户信息&a…

AIGC迈向通用人工智能时代

一、AIGC“起飞”的背后 2023年1月30日&#xff0c;AIGC概念股突飞猛涨。一时间&#xff0c;AIGC再次站上风口浪尖。 AIGC&#xff08;AI Generated Content&#xff09;是指利用人工智能技术来生成内容&#xff0c;被认为是继UGC、PGC之后的新型内容生产方式&#xff0c;常见…

哈希的应用 -- 布隆过滤器与海量数据处理

文章目录 布隆过滤器概念布隆过滤器设计思路布隆过滤器的应用布隆过滤器模拟实现布隆过滤器的基本框架布隆过滤器的插入布隆过滤器的探测布隆过滤器的删除 布隆过滤器优点布隆过滤器缺陷布隆过滤器模拟实现代码及测试代码海量数据处理哈希切割哈希切分 布隆过滤器概念 布隆过滤…

【机器学习】HOG+SVM实现行人检测

文章目录 一、准备工作1. 下载数据集2. 解压数据集 二、HOG特征简介1. 梯度&#xff08;Gradient&#xff09;2. 格子&#xff08;Cell&#xff09;3. 块归一化&#xff08;Block Normalization&#xff09;4. HOG特征&#xff08;HOG Feature&#xff09;5. 使用skimage.featu…

“五一”假期消防安全知识要牢记之消防安全知识答题活动

“五一”期间&#xff0c;容易出现哪些安全隐患&#xff0c;生产生活中要注意哪些安全事项&#xff0c;一起来看&#xff01; 森林防火&#xff1a; 1.禁止将火柴、汽油等易燃物带入山林&#xff0c;禁止乱扔火种。 2.景区管理单位要加强防火巡逻&#xff0c;禁止野外火源&am…

smbms项目搭建

目录 1.搭建一个maven web项目 2.配置Tomcat 3.测试项目是否能够跑起来 4.导入项目中会遇到的Jar包 5.项目结构搭建 6.项目实体类搭建 7.编写基础公共类 1.数据库配置文件 2.编写数据库的公共类 3.编写字符编码过滤器 3.1web配置注册 4.导入静态资源 1.搭建一个maven web项目 …

C++前置声明的理解

知识补充 在C/C中引入一个头文件时&#xff0c;在编译器预处理的时候会将引入头文件的地方简单替换成头文件的内容。这样做的后果是很容易引起头文件的重复引用。所以我们在编写头文件是一般有以下规定来防止头文件被重复包含。 MyWidget.h #ifndef MyWidget_H_ #define MyWi…

实验四、彩色图像处理

实验目的 使用MatLab软件对图像进行彩色处理&#xff0c;熟悉使用MatLab软件进行图像彩色处理的有关方法&#xff0c;并体会到图像彩色处理技术以及对图像处理的效果。 作业1&#xff1a;生成一副256*256的RGB图像&#xff0c;使得该图像左上角为黄色或者青色&#xff0c;左下…

day04_基本数据类型丶变量丶类型转换

前置知识 计算机世界中只有二进制。那么在计算机中存储和运算的所有数据都要转为二进制。包括数字、字符、图片、声音、视频等。 进制 进制也就是进位计数制&#xff0c;是人为定义的带进位的计数方法 。不同的进制可以按照一定的规则进行转换。 进制的分类 十进制&#x…

Seurat -- Perform linear dimensional reduction

brief 什么是线性降维&#xff1f; 这里是一个很形象的网页演示&#xff0c;其中包括了一个视频链接。 这里是如何用R 包psych做线性降维的演示&#xff0c;其中也有原理的简述。 为什么要做线性降维&#xff1f; 因为下一步的聚类分析需要这里的降维结果作为输入。降维做的好…