• SystemV共享内存


    一、原理

    申请:与共享库类似,OS先在共享区开辟/申请一段共享内存,然后通过页表映射,挂接到进程地址空间,返回这块内存的首地址,使得不同进程能访问同一份资源。

    释放:去关联+释放共享内存

    一个进程可以有多块共享内存,一块共享内存可以被多个进程使用,需要相应管理的struct。

    二、shmget(shared memory)

    1、key

    判断该共享内存是否已经存在

    ftok形成一个key

    是一套算法,利用pathname和proj_id形成唯一标识的key,尽量保证不重复(冲突概率低的)

    冲突时就会调用失败

    2、生命周期随内核不随进程

    ipcs -m查看所有的共享内存

    ipcrm -m 释放共享内存 + shmid

    nattch表示连接的进程数

    3、perms权限

    4、createShm和getShm封装

    三、shmat(attach)

    1、nattch

     while :; do ipcs -m | head -3 && ipcs -m | grep LZF;sleep 1;done;

    四、shmdt(解除关联,不用杀进程)

    五、shmctl控制

    删除共享内存

    六、建立2个进程通信过程

    1. #include"comm.hpp"
    2. int main()
    3. {
    4. int shmid = CreateShm();
    5. log(Info,"Create Shm success");
    6. sleep(3);
    7. char* shmaddr = (char*)shmat(shmid,nullptr,0);
    8. log(Debug,"shmat success, shmaddr:0x%x",shmaddr);
    9. sleep(3);
    10. shmdt(shmaddr);
    11. log(Debug,"shmdt success,shmaddr:0x%x",shmaddr);
    12. sleep(5);
    13. //log(Info,"processa quit");
    14. shmctl(shmid,IPC_RMID,nullptr);
    15. log(Debug,"destroy shm done,shmaddr:0x%x",shmaddr);
    16. sleep(5);
    17. return 0;
    18. }
    1. #include"comm.hpp"
    2. int main()
    3. {
    4. int shmid = GetShm();
    5. char* shmaddr = (char*)shmat(shmid,nullptr,0);
    6. log(Debug,"shmat success, shmaddr:0x%x",shmaddr);
    7. sleep(3);
    8. shmdt(shmaddr);
    9. log(Debug,"shmdt success,shmaddr:0x%x",shmaddr);
    10. sleep(5);
    11. return 0;
    12. }

    七、利用共享内存实现进程间通信

    直接往映射后的虚拟地址shmaddr写入和读取即可。

    八、共享内存的特性

    速度快---拷贝次数少

    九、共享内存的属性

    十、利用管道实现同步与互斥

    attach后建立管道,写端写入共享内存后,向管道传一个字符,读端接收后,开始从共享内存中读取。

    读端会阻塞,只用共享内存就会一直读。

  • 相关阅读:
    【Java基础面试二】、为什么Java代码可以实现一次编写、到处运行?
    【强连通+背包】CF1763E
    10.4号作业
    配置与管理Samba服务器复习题
    【3D目标检测】OpenPCDet自定义数据集训练
    Flume学习笔记(1)—— Flume入门
    Swift-30-高级编程-类型扩展和协议扩展
    HarmonyOS学习路之方舟开发框架—学习ArkTS语言(状态管理 六)
    【深度优先搜索】leetcode 1020. 飞地的数量
    如何注册Liberty大学并获取Perplexity Pro
  • 原文地址:https://blog.csdn.net/lzfnb666/article/details/134502329