共享内存

共享内存是最高效的IPC机制,因为它不涉及进程之间的任何数据传输。

1、实现原理

共享内存区域说白了就是多个进程共享的一块物理内存地址,只是将这块物理内存分别映射到自己的虚拟空间地址上。假设有10个进程将这块区域映射到自己的虚拟地址上,那么这10个进程就可以相互通信。由于是同一块区域在这10个进程的虚拟地址上,当第一个进程向这块共享内存的虚拟地址中写入数据时,其他9个进程也会看到。因此共享内存是进程间通讯的一种最快的方式。但进程之间使用这块共享空间时,必须做到同步控制。

2、相关函数

shmget()        shmat()         shmdt()         shmctl()      它们的头文件都是sys/shm.h,下面我们来详细说明

shmget()函数

shmget系统调用创建一段新的共享内存或者获取一段已经存在的共享内存,其函数原型如下:

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

key是一个键值,用来标识全局唯一的共享内存,size指定共享内存的大小,单位是字节。如果是创建新的共享内存,则size值必须被指定,如果是获取已经存在的共享内存,则可以把size设置为0。shmflg包含9个比特的权限标志,它们的作用与创建文件是使用的标志一样。

如果共享内存创建成功,shmget返回一个非负整数,即共享内存标识符;失败返回-1.

shmat() 函数

第一次创建共享内存段时,它不能被任何进程访问。想要启动对该内存的访问,必须将其连接到一个进程的地址空间中。这项工作由shmat函数来完成,它的函数原型如下:

void *shmat(int shm_id,const void*shm_addr,int shmflg);

shm_id是由shmget返回的共享内存标识符,shm_addr指定的是共享内存连接到当前进程中的地址位置,它通常是一个空指针,表示让系统来选择共享内存出现的地址。shmflg是一组位标志,它的两个可能取值是SHM_RND(这个标志与shm_addr联合使用,用来控制共享内存链接的地址)和SHM_RDONLY(它使得连接的内存只读)。

如果shmat调用成功,它返回一个指向共享内存第一个字节的指针;失败返回-1.

shmdt()函数

函数原型如下:

int shmdt(const void *shm_addr);

shmctl()函数

shmctl系统调用控制共享内存的某些属性,它的函数原型如下:

int shmclt(int shm_id,int command,struct shmid_ds *buf);

shm_id是shmget调用返回的共享内存标识符,command指定要执行的命令,buf是一个指针,指向包含内存模式和访问权限的结构。

shmctl成功时返回值取决于command,失败返回-1.

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值