[发明专利]一种多进程间的数据交换方法和系统在审
申请号: | 201711132105.2 | 申请日: | 2017-11-15 |
公开(公告)号: | CN107992368A | 公开(公告)日: | 2018-05-04 |
发明(设计)人: | 张冬明;靳国庆;包秀国;袁庆升;云晓春;刘洋;王万能 | 申请(专利权)人: | 国家计算机网络与信息安全管理中心;中国科学院计算技术研究所 |
主分类号: | G06F9/54 | 分类号: | G06F9/54;G06F9/52 |
代理公司: | 北京律诚同业知识产权代理有限公司11006 | 代理人: | 祁建国,梁挥 |
地址: | 100031*** | 国省代码: | 北京;11 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | 本发明涉及一种多进程间的数据交换方法和系统,包括使用共享内存及域名套接字混合架构交换数据,并将共享内存划分为N个节点空间,进行数据共享,而使用域名套接字对共享内存中的数据进行同步。由于每个进程在访问节点空间之前都使用互斥锁访问标识位,避免了读内存和写内存之间的冲突。节点空间的标识位和互斥锁的搭配使用,使得数据生产进程和多个数据消费进程之间互斥,而多个数据消费进程之间可以同时访问同一片内存,使得数据消费进程不会造成因加锁而造成性能下降。 | ||
搜索关键词: | 一种 进程 数据 交换 方法 系统 | ||
【主权项】:
一种多进程间的数据交换方法,其特征在于,包括:数据消费进程启动步骤,启动多个数据消费进程,并向操作系统申请共享内存空间;共享内存空间划分步骤,启动一个数据生产进程,该数据生产进程和该数据消费进程使用相同的规则定义数据管理单元,并将该共享内存空间按照该数据管理单元的格式划分为N个节点空间,其中N为正整数;第一节点空间选取步骤,选取某一节点空间作为待写节点空间;数据写入步骤,该数据生产进程访问该待写节点空间的标识位,若该待写节点空间的标识位为空闲状态,则将其置为在写状态,同时该数据生产进程向该待写节点空间写入数据,写入完成后将标识位置为空闲状态,若该待写节点空间的标识位为在读状态,则放弃该待写节点空间,选取下一个节点空间作为该待写节点空间;同步数据元组发送步骤,重复调用该数据写入步骤,将该数据生产进程产生的数据依次写入N个节点空间中,并且每写完num个节点空间就通过域名套接字将同步数据元组发送到该数据消费进程,其中num为大于1小于N的正整数;第二节点空间选取步骤,该数据消费进程通过解析该域名套接字,得到可用节点空间,并根据该可用节点空间,选取某一节点空间作为待读节点空间;数据读取步骤,该数据消费进程访问该待读节点空间的标识位,若该待读节点空间的标识位为空闲状态或在读状态,则将其置为在读状态,同时该数据消费进程读取并处理该待读节点空间内数据,处理完成后将标识位置为空闲状态,若该待读节点空间的标识位为在写状态,则放弃该待读节点空间,根据该可用节点空间,选取下一个节点空间作为待读节点空间;重复步骤,重复调用该数据读取步骤,直到所有该数据消费进程均完成数据的读取和处理。
下载完整专利技术内容需要扣除积分,VIP会员可以免费下载。
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于国家计算机网络与信息安全管理中心;中国科学院计算技术研究所,未经国家计算机网络与信息安全管理中心;中国科学院计算技术研究所许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/patent/201711132105.2/,转载请声明来源钻瓜专利网。
- 上一篇:一种MFC和PCB的连接结构
- 下一篇:一种智能型高压电流测量装置
- 数据显示系统、数据中继设备、数据中继方法、数据系统、接收设备和数据读取方法
- 数据记录方法、数据记录装置、数据记录媒体、数据重播方法和数据重播装置
- 数据发送方法、数据发送系统、数据发送装置以及数据结构
- 数据显示系统、数据中继设备、数据中继方法及数据系统
- 数据嵌入装置、数据嵌入方法、数据提取装置及数据提取方法
- 数据管理装置、数据编辑装置、数据阅览装置、数据管理方法、数据编辑方法以及数据阅览方法
- 数据发送和数据接收设备、数据发送和数据接收方法
- 数据发送装置、数据接收装置、数据收发系统、数据发送方法、数据接收方法和数据收发方法
- 数据发送方法、数据再现方法、数据发送装置及数据再现装置
- 数据发送方法、数据再现方法、数据发送装置及数据再现装置