Linux共享内存

共享内存是Linux下最快速、最有效的进程间通信方式。是多个进程可以把同一段内存映射到自己的进程空间,以此实现数据的共享与传输。即:对于不同的进程A、B,将同一块物理内存映射到进程A、B各自进程的地址空间,进程A能够及时地看到进程B对共享内存中数据的更新,反之B进程同样能够及时地看到进程A对共享内存中数据的更新。

共享内存存在于内核级别的一种资源,因此是所有进程间通信(IPC)方式中最快的一种。在shell中通过命令ipcs可以查看当前系统IPC中的状态:

    <span style="font-size:14px;">[xcbeyond@bogon /]$ ipcs
     
    ------ Shared Memory Segments --------
    key        shmid      owner      perms      bytes      nattch     status      
    0x000000001 32768     xcbeyond    600        655360     2
    0xfffffffff 589825    xcbeyond    0          4096       0
     
     ------ Semaphore Arrays --------
    key        semid      owner      perms      nsems     
     
    ------ Message Queues --------
    key        msqid      owner      perms      used-bytes   messages </span>

        在系统内核为一个进程分配内存地址时,通过分页机制可以让一个进程的物理地址不连续,同时也可以让同一段内存分配给不同的进程。共享内存机制就是通过该原理来实现的,共享内存只是提供数据的传送,而如何确保进行服务器端和客户端读写操作的互斥性,就需要一些其他的方式来控制了,例如信号量。

更多请见:http://www.mark-to-win.com/tutorial/50485.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值