进程间通讯——共享内存
来源:互联网 发布:事件驱动模型 php 编辑:程序博客网 时间:2024/06/01 09:21
1、概念:
共享内存是两个正在运行的进程之间传递数据的一种有效的方式。
2、机制:
共享内存是由IPC为进程创建的一个特殊的地址范围,它将出现在该进程的地址空
间中,其他正在运行的进程可以将同一段共享内存连接到自己的地址空间中。所
有的进程都可以访问共享内存的地址。如果某个进程向共享内存中写入了数据,
那么写入的数据就可以被访问同一段共享内存的其他进程看到。
下图简单描述共享内存是如何工作的:
3、特点:
共享内存是最快的一种IPC,在各个进程都有指针指向开辟的共享内存区域,进程访
问时共享内存数据时就当作本进程的一个内存控制进行操作。
4、共享内存操作:
(1) shmget函数:创建或获取共享内存;
int shmget(key_t key,size_t size,int shmflg);
key:与信号量一样,程序需要提供一个参数key来有效的为共享内存段命名;
有一个特殊的键值IPC_PRIVATE,它用于创建一个只属于创建进程的共
享内存,但不常会用到;
size: 以字节为单位指定需要共享的内存容量;
shmflg:与创建文件时使用的mode标志一样;IPC_CREAT:共享内存存在时获
取,不存在时创建;
返回值:成功时返回一个共享内存标识符,用于后续的共享内存函数;失败时返回-1;
(2) shmat函数:连接共享内存;
void* shmat(int shm_id,const void* shm_addr.int shmflg);
shm_id:由shmget函数返回的共享内存标识符;
shm_addr:指定共享内存连接到当前进程中的地址位置,通常是一个空指针,表示
让系统来选择共享内存出现的地址;
shmflg:是一组位标志,有两个可能取值是SHM_RND和SHM_RDONLY,
SHM_RND通常与shm_addr联合使用来控制共享内存连接的地址,
SHM_RDONLY使得连接的内存只读;
返回值:调用成功返回一个指向共享内存第一个字节的指针,调用失败返回-1.
(3) shmdt函数:将共享内存从当前进程中分离;
int shmdt(void* ptr);
此函数只完成断开连接操作,并不会删除共享内存。
(4) shmctl函数:删除内核对象;
int shmctl(int shm_id,int command,struct shmid_ds *buf);
shm_id:由shmget函数返回的共享内存标识符;
command:要采取的动作;
buf:指向包含共享内存模式和访问没权限的结构体;
返回值:成功时返回0,失败时返回-1;
注:共享内存是两个以上的进程能够操作同一块物理空间的内存区域,所以共享的区域
就成了临界资源,所以对于共享区域的访问必须做同步控制。
- 进程间通讯 —— 共享内存
- 进程间通讯——共享内存
- 进程间通讯——共享内存
- 进程间通讯——共享内存
- 进程间通讯—共享内存
- 缓冲区设计—进程间通讯(POSIX 共享内存)
- 进程间通讯-共享内存
- 进程间通讯----共享内存
- 进程间通讯---共享内存
- 进程间通讯-共享内存
- 进程间通讯:共享内存
- 进程间通讯概述管道通讯信号通讯共享内存
- Linux笔记_进程通讯——共享内存
- 进程间通讯-共享内存2(代码)
- 进程间通讯共享内存的具体步骤
- 使用内存共享机制进程间通讯
- 共享内存实现进程间通讯
- 共享内存实现进程间通讯 收藏
- 函数返回对象和对象的生命周期的结合
- 【最详细】将github上的项目源码导入eclipse详细教程
- nginx+wusgi部署django
- ContentProvide简单使用
- 移植u-boot-2012.04----支持DM9000网卡
- 进程间通讯——共享内存
- 2017腾讯LIVE开发者大会精彩回顾!
- MySQL总结(一)
- 11月面【三】
- A. Borya's Diagnosis
- 解决npm 的 shasum check failed for错误
- Android弹出式窗口PopuWindow的使用
- Java基础--3常量
- leetcode add two numbers