zoukankan      html  css  js  c++  java
  • 【框架】共享内存组设计思路与实现(更新中)

    版权声明:本文为博主原创文章,转载前请注明出处:https://www.cnblogs.com/schips/p/10677408.html。


    背景:

      在通信场景中,存在一个进程A,专门用来处理某个设备文件的消息,并将从设备文件中读取到的信息放置到某片共享内存中,只要和其他进程约定好共享内存使用的shm_id即可。

      现在由于业务拓展,需要同时处理不同的设备文件,如果使用相同的shm_id会导致先申请内存值被后者覆盖(根本原因是由于不同的数据对象使用了同一片的内存地址,导致读写时发生了数据践踏。

    现在提出一种解决该方法的框架:共享内存管理器。

    设计:

      核心思想是在共享内存内存中设计一种公共对象,专门用于存储子shm_id。

      所有的生产者与消费者在申请自己需要使用的共享内存之前,都先在公共对象的指定区域进行查找,如果没有,则登记注册;否则直接使用(同时维护一个计数器,每当有一个新的进程使用时,计数器的值自增;当使用者退出时,计数器自减,当计数器减为0时,注销该子共享内存。)

      (相当于在酒店住房间的时候,先去前台注册;然后拿着自己的钥匙去自己的房间,当房间的最后一个人离开时,退房)

      这样,就可以保证以前的接口不会发生很大的变化就可以实现兼容。

    未完待续。

  • 相关阅读:
    acm的STL容器之vector篇
    服务器远程管理方法及centos该装那个
    VB获取对象成员
    获取搜索引擎关键字建议
    IntelliJ IDEA乱码 问题
    排序算法思想
    ubuntu16 开机启动plank
    fail-fast出识
    html 标签过滤、转译、反转译
    (a ==1 && a== 2 && a==3) 有可能是 true 吗?
  • 原文地址:https://www.cnblogs.com/schips/p/10677408.html
Copyright © 2011-2022 走看看