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

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


    背景:

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

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

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

    设计:

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

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

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

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

    未完待续。

  • 相关阅读:
    SpringMVC+Huploadify 实现文件上传下载
    删除代码中的注释
    shiro框架学习(二)
    shiro框架学习(三)
    shiro框架学习(一)
    数据库操作导入导出以及加快查询速度
    判断字符串中是否是数字
    分数判断
    异常处理的课后
    多态的课后总结
  • 原文地址:https://www.cnblogs.com/schips/p/10677408.html
Copyright © 2011-2022 走看看