Linux--ipcs、共享内存、共享接口简介

1.ipcs命令

ipcs -s: 只查看信号量 ;
ipcs -m: 只查看共享内存 ;
ipcs -q: 只查看消息队列 ;
删除信号量 :
ipcrm -s 编号 ;

2.共享内存

共享内存为多个进程之间共享和传递数据提供了一种有效的方式。共享内存是先在物
理内存上申请一块空间,多个进程可以将其映射到自己的虚拟地址空间中。 所有进
程都可以访问共享内存中的地址,就好像它们是由 malloc 分配的一样。如果某个进
程向共享内存写入了数据,所做的改动将立刻被可以访问同一段共享内存的任何其他
进程看到。 由于它并未提供同步机制,所以我们通常需要用其他的机制来同步对共享
内存的访问。

3.共享内存接口介绍

(1)shmget
int shmget ( key_t key , size_t size , int shmflg );
shmget () 用于创建或者获取共享内存
shmget () 成功返回共享内存的 ID , 失败返回 - 1
key : 不同的进程使用相同的 key 值可以获取到同一个共享内存 ,( 注意 : 这里的值和信号
量的 值一样也没有关系 , 因为类型不一样 ;)
size : 创建共享内存时,指定要申请的共享内存空间大小
shmflg : IPC_CREAT IPC_EXCL

(2)shmat  

void* shmat ( int shmid , const void * shmaddr , int shmflg );
shmat () 将申请的共享内存的物理内存映射到当前进程的虚拟地址空间上
shmat () 成功返回返回共享内存的首地址,失败返回 NULL ( malloc 一样给共享空间的起
始地址 ), 看帮助手册失败返回的是 ( void * ) - 1 ;
shmaddr :一般给 NULL ,由系统自动选择映射的虚拟地址空间
shmflg : 一般给 0 ( 0 就代表的可读可写 ) , 可以给 SHM_RDONLY 为只读模式,其他
的为读写

 (3)shmdt

int shmdt ( const void * shmaddr );
shmdt () 断开当前进程的 shmaddr 指向的共享内存映射
shmdt () 成功返回 0 , 失败返回 - 1

(4)shmctl

int shmctl ( int shmid , int cmd , struct shmid_ds * buf );
shmctl () 控制共享内存
shmctl () 成功返回 0 ,失败返回 - 1
cmd IPC_RMID

  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值