[发明专利]循环队列的数据写入方法、装置、终端设备和存储介质有效

专利信息
申请号: 201810358392.7 申请日: 2018-04-20
公开(公告)号: CN108710531B 公开(公告)日: 2021-06-15
发明(设计)人: 陈柳章 申请(专利权)人: 深圳市文鼎创数据科技有限公司
主分类号: G06F9/48 分类号: G06F9/48;G06F9/54
代理公司: 深圳中一联合知识产权代理有限公司 44414 代理人: 李艳丽
地址: 518000 广东省深圳市南山区粤海街道*** 国省代码: 广东;44
权利要求书: 查看更多 说明书: 查看更多
摘要:
搜索关键词: 循环 队列 数据 写入 方法 装置 终端设备 存储 介质
【权利要求书】:

1.一种循环队列的数据写入方法,其特征在于,包括:

当任意一个线程准备写入数据至循环队列时,判断当前是否有其它线程正在写入数据至所述循环队列;

若当前有其它线程正在写入数据至所述循环队列,则在预设时长之后,返回执行判断当前是否有其它线程正在写入数据至所述循环队列的步骤以及后续步骤;

若当前没有其它线程正在写入数据至所述循环队列,则各个线程使用比较并交换机制的原子操作方式竞争第一指针,所述第一指针指向循环队列中下一个可写入数据的位置;

由竞争第一指针成功的线程将数据写入所述循环队列;

其中,当前是否有其它线程正在写入数据至所述循环队列通过以下步骤判定:

若所述第一指针和第二指针指向同一个位置,则判定当前没有其它线程正在写入数据至所述循环队列,所述第二指针指向循环队列中可读出数据的最大位置的下一个位置;

若所述第一指针和第二指针不是指向同一个位置,则判定当前有其它线程正在写入数据至所述循环队列;

若当前有其它线程正在写入数据至所述循环队列,则在延时预设时长之前,还包括:

判断当前正在写入数据至所述循环队列的线程是否产生异常;

若当前正在写入数据至所述循环队列的线程产生异常,则使用比较并交换机制的原子操作方式将所述第二指针推进至所述第一指针指向的位置。

2.如权利要求1所述的循环队列的数据写入方法,其特征在于,所述由竞争第一指针成功的线程将数据写入所述循环队列包括:

将所述第一指针从当前位置推进至下一个位置;

由竞争第一指针成功的线程往所述当前位置写入数据;

将所述第二指针推进至所述第一指针指向的位置。

3.如权利要求1所述的循环队列的数据写入方法,其特征在于,在判断当前是否有其它线程正在写入数据至所述循环队列之前,还包括:

初始化计数器的计数值;

当前正在写入数据至所述循环队列的线程是否产生异常通过以下步骤判定:

若所述计数值达到第一阈值,则判定当前正在写入数据至所述循环队列的线程产生异常;

若所述计数值未达到所述第一阈值,则判定当前正在写入数据至所述循环队列的线程未产生异常;

在判断当前正在写入数据至所述循环队列的线程是否产生异常之后,还包括:

若当前正在写入数据至所述循环队列的线程未产生异常,则累计所述计数值一次,然后执行延时预设时长的步骤。

4.如权利要求3所述的循环队列的数据写入方法,其特征在于,在初始化计数器的计数值之前,还包括:

记录所述第一指针指向的目标位置;

若当前正在写入数据至所述循环队列的线程未产生异常,则在累计所述计数值一次之前,还包括:

判断所述第一指针当前是否指向所述目标位置;

若所述第一指针当前指向所述目标位置,则执行累计所述计数值一次的步骤;

若所述第一指针当前不是指向所述目标位置,则返回记录所述第一指针指向的目标位置的步骤;

在使用比较并交换机制的原子操作方式将所述第二指针推进至所述第一指针指向的位置之后,还包括:

若使用比较并交换机制的原子操作方式将所述第二指针推进至所述第一指针指向的位置失败,则返回记录所述第一指针指向的目标位置的步骤。

下载完整专利技术内容需要扣除积分,VIP会员可以免费下载。

该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于深圳市文鼎创数据科技有限公司,未经深圳市文鼎创数据科技有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服

本文链接:http://www.vipzhuanli.com/pat/books/201810358392.7/1.html,转载请声明来源钻瓜专利网。

×

专利文献下载

说明:

1、专利原文基于中国国家知识产权局专利说明书;

2、支持发明专利 、实用新型专利、外观设计专利(升级中);

3、专利数据每周两次同步更新,支持Adobe PDF格式;

4、内容包括专利技术的结构示意图流程工艺图技术构造图

5、已全新升级为极速版,下载速度显著提升!欢迎使用!

请您登陆后,进行下载,点击【登陆】 【注册】

关于我们 寻求报道 投稿须知 广告合作 版权声明 网站地图 友情链接 企业标识 联系我们

钻瓜专利网在线咨询

周一至周五 9:00-18:00

咨询在线客服咨询在线客服
tel code back_top