进程间通信--IPC之共享内存

一、共享内存
共享内存可以提供给服务器进程和客户进程之间进行通信,不需要进行数据的复制,所以速度是最快的,只需要让两个进程通过页表映射到同一块物理内存上面即可,这块物理内存是两个进程都可以访问到的,所以信息传递的效率是非常高的。在通常情况下,我们要确保的是一个进程在进行读的时候,另一个进程不能去执行写操作,这是同过信号量来实现的。共享内存是最快的一种IPC。
下面我们来看一下,共享内存实现的原理图:
这里写图片描述
利用共享内存来完成进程之间的通信,两个进程读通过虚拟地址空间到用户页表,再从用户页表到物理内存之间的一块共享的内存区域,这样的话就可以实现两个进程之间的通信。
这里写图片描述

二、共享内存中的结构体

ipc_perm这个结构体,在消息队列、信号量、共享内存中都是存在的。
      struct ipc_perm {
               key_t          __key;    /* Key supplied to shmget(2) */
               uid_t          uid;      /* Effective UID of owner */
               gid_t          gid;      /* Effective GID of owner */
               uid_t          cuid;     /* Effective UID of creator */
               gid_t          cgid;     /* Effective GID of creator */
               unsigned short mode;     /* Permissions + SHM_DEST and
                                           SHM_LOCKED flags */
               unsigned short __seq;    /* Sequence number */
           };

shmid_ds这个结构体的第一个参数就是一个ipc_perm类型的成员。这个结构体用来描述共享内存的id的。
          struct shmid_ds {
               struct ipc_perm shm_perm;    /* Ownership and permissions */
               size_t          shm_segsz;   
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值