Linux之用信号量实现的共享内存机制

首先介绍一个概念IPC
IPC(Inter-Process Communication)机制即进程间通信机制,我们最为熟悉的IPC机制有三种,即信号量、共享内存和消息队列。今天要介绍的共享内存机制就是IPC三大机制之一。
一.共享内存先知
共享内存是在两个正在运行的进程之间传递数据的一种非常有效的方法,它允许两个不想管的进程访问同意逻辑内存,虽然X/Open标准并没有对它做出要求,但是大多数共享内存的具体实现都把由不同进程之间共享的内存安排为同一物理内存。
二.共享内存实现的有关函数
共享内存使用的函数类似于信号量的函数,它们的定义如下:
有关共享内存的函数包含在头文件:

#include<sys/shm.h>

创建(获取)共享内存的函数shmget()

int shmget(key_t key,size_t size,int shmflg)
//第一个参数key,为共享内存段命名
//第二个参数size,以字节为单位指定需要共享的内存容量
//第三个参数simflg,是一个包含9个比特的权限标志

将共享内存空间映射(链接)到当前进程地址空间的函数shmat()

void *shmat(int shm_id,const void *shm_addr,int shmflg)
//第一个参数shm_id,是由shmget返回的共享内存标识码
//第二个参数shm_addr,指定共享内存连接到当前进程中的地址位置
//第三个参数shmflg,一组位标志

断开映射(连接)的函数shmdt()

int shmdt(const void *shm_addr)
//参数shm_addr,是shmat返回的地址指针,成功返回0,失败返回-1

共享内存的控制函数(属性控制/删除共享内存)shmctl()

int shmctl(int shm_id,int command,struct shmid_ds *buf)
//第一个参数shm_id,是shmget返回的共享内存标识符
//第二个参数command,是要采取的动作
  • 1
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值