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 , 失败返回 - 1key : 不同的进程使用相同的 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 ,失败返回 - 1cmd : IPC_RMID