Linux进程间通信之共享存储

本文详细介绍了Linux进程间通信中的共享存储,包括其定义、特点、相关函数(shmget, shmat, shmdt, shmctl)的使用,以及如何通过信号量同步对共享内存的访问。通过实例展示了共享内存的创建、连接和删除过程。" 83655808,7169296,使用Echarts创建类环形散点图,"['前端开发', 'JavaScript', '数据可视化', 'Echarts', '图表']

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Linux进程间通信之共享存储

一、定义:共享存储允许两个或多个进程共享一个给定的存储区。因为数据不需要在客户进程和服务器之间复制,所以这是最快的之中IPC。

使用共享存储时要掌握的唯一窍门是,在多个进程之间同步访问一个给定的存储区。若服务器进程正在将数据放入共享存储区,则在它做完这一操作之前,客户进程不应当去取这些数据。通常,信号量用于同步共享存储访问。(不过正如部分所述,也可以用记录锁或者互斥量)

二、特点:
1.共享内存是最快的一种 IPC,因为进程是直接对内存进行存取。
2.因为多个进程可以同时操作,所以需要进行同步。
3.信号量+共享内存通常结合在一起使用,信号量用来同步对共享内存的访问。

三、相关函数:
1.函数shmget

NAME
       shmget - allocates a shared memory segment

SYNOPSIS
       #include <sys/ipc.h>
       #include <sys/shm.h>

       int shmget(key_t key, size_t size, int shmflg);
		//返回值:成功返回共享内存ID,失败返回-1

①功能:创建或获取一个共享内存。
②参数:
*key:键。
*size:是该共享存储的长度,以字节为单位。
实现通常将其向上取为系统页长的整倍数。但是,若应用指定的size值并非系统页长的整倍数,那么最后一页的余下部分是不可使用的。如果正在创建一个新段(通常在服务器进行中),则必须指定其size。如果正在引用一个现存的段(一个客户进程),则将size指定为0.当创建一个新段时,段内的内容初始化为0.
*flag:
① 0:取共享内存标识符,若不存在则函数会报错
② PC_CREAT:当shmflg&IPC_CREAT为真时,如果内核中不存在键值与key相等。
的共享内存,则新建一个共享内存;如果存在这样的共享内存,返回此共享内存的标识符。
③ IPC_CREAT|IPC_EXCL:如果内核中不存在键值 与key相等的共享内存,则新建一个共享内存;如果存在这样的共享内存则报错。

2.函数shmat

	void *shmat(int shmid, const void *addr, int flag)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值