进程间通信——共享内存(Shared Memory)

共享内存是一种高效的数据交换方式,允许不同进程访问同一逻辑内存。在Linux中,通过页表映射实现不同进程间的共享,但需借助其他同步机制如信号量防止数据冲突。本文介绍了共享内存的创建、映射、读写、销毁等步骤,以及相关接口函数如shmget、shmat、shmdt和shmctl的使用。同时,概述了共享内存通信的优点和缺点,包括其无需数据传送的高效性以及需要额外同步机制的挑战。
摘要由CSDN通过智能技术生成

什么是共享内存

顾名思义, 共享内存就是允许两个不相关的进程访问同一个逻辑内存。共享内存是在两个正在运行的进程之间共享和传递数据的一种非常有效的方式。不同进程之间共享的内存通常安排为同一段物理内存。进程可以将同一段共享内存连接到它们自己的地址空间中,所有进程都可以访问共享内存中的地址,就好像它们是由用C语言函数malloc分配的内存一样。而如果某个进程向共享内存写入数据,所做的改动将立即影响到可以访问同一段共享内存的任何其他进程。

需要注意的是:共享内存并未提供同步机制,也就是说,在第一个进程结束对共享内存的写操作之前,并无自动机制可以阻止第二个进程开始对它进行读取,所以我们通常需要用其他的机制来同步对共享内存的访问,例如: 信号量

共享内存的通信原理

Linux中,每个进程都有属于自己的进程控制模块(PCB)地址空间(Addr Space),并且都有一个与之对应的页表,负责将进程的虚拟地址与物理地址进行映射,通过内存管理单元(MMU)进行管理。两个不同的虚拟地址通过页表映射到物理空间的同一区域,它们所指向的这块区域即共享内存
例子:
有一个A B进程。我们说A进程有它自己的一个独立的存储空间,而B进程也有一个独立的存储空间,当中怎么实现数据的交流呢?在内存当中有一块公共的内存shm,也就是说,A可以把shm的内存地址拿到,而B也可以把shm的内存地址拿到,他们都面向同一个物理内存

在这里插入图片描述

共享内存的基本编写方式

1.创建共享内存/打开
2.映射共享内存
3.进行数据的交换/编写
4.释放共享内存
5.销毁共享内存

共享内存的接口函数及基本指令

1.查看系统中的共享内存

ipcs -m

2.删除系统中的共享内存

ipcrm -m [shmid]

3.shmget ( ):创建共享内存

int shmget(key_t key, size_t size, int shmflg);

[参数key] :由ftok()函数生成的key标识,标识系统的唯一IPC资源。

[参数size] :共享内存的大小,注意:共享内存的大小必须已兆对齐:1024*4

[参数shmflg] :如果是创建共享内存的,使用IPC_CREAT|0666(权限)。

[返回值] :创建成功返回共享内存的ID,失败则返回-1。

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值