[发明专利]循环队列的数据写入方法、装置、终端设备和存储介质有效
申请号: | 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所述的循环队列的数据写入方法,其特征在于,在初始化计数器的计数值之前,还包括:
记录所述第一指针指向的目标位置;
若当前正在写入数据至所述循环队列的线程未产生异常,则在累计所述计数值一次之前,还包括:
判断所述第一指针当前是否指向所述目标位置;
若所述第一指针当前指向所述目标位置,则执行累计所述计数值一次的步骤;
若所述第一指针当前不是指向所述目标位置,则返回记录所述第一指针指向的目标位置的步骤;
在使用比较并交换机制的原子操作方式将所述第二指针推进至所述第一指针指向的位置之后,还包括:
若使用比较并交换机制的原子操作方式将所述第二指针推进至所述第一指针指向的位置失败,则返回记录所述第一指针指向的目标位置的步骤。
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于深圳市文鼎创数据科技有限公司,未经深圳市文鼎创数据科技有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/201810358392.7/1.html,转载请声明来源钻瓜专利网。
- 数据显示系统、数据中继设备、数据中继方法、数据系统、接收设备和数据读取方法
- 数据记录方法、数据记录装置、数据记录媒体、数据重播方法和数据重播装置
- 数据发送方法、数据发送系统、数据发送装置以及数据结构
- 数据显示系统、数据中继设备、数据中继方法及数据系统
- 数据嵌入装置、数据嵌入方法、数据提取装置及数据提取方法
- 数据管理装置、数据编辑装置、数据阅览装置、数据管理方法、数据编辑方法以及数据阅览方法
- 数据发送和数据接收设备、数据发送和数据接收方法
- 数据发送装置、数据接收装置、数据收发系统、数据发送方法、数据接收方法和数据收发方法
- 数据发送方法、数据再现方法、数据发送装置及数据再现装置
- 数据发送方法、数据再现方法、数据发送装置及数据再现装置