精易论坛

标题: 易版环形缓冲区 理论上支持多线程 [打印本页]

作者: incwin    时间: 2021-5-15 18:19
标题: 易版环形缓冲区 理论上支持多线程
本帖最后由 Jy倾恋 于 2021-5-16 14:22 编辑
这个环形缓冲区是基于 http://circularbuffer.codeplex.com/、 http://en.wikipedia.org/wiki/Circular_buffer 修改的
最近自己项目用到的一个缓冲区,理论上支持多线程
在自己的多线程项目测试过,暂时没有问题

下面科普下环形缓冲区在内存里的变化:

环形缓冲区首先从空开始并具有设置的长度;在下图中,是一个7字节的缓冲区:



假设在环形缓冲区的中心写入1(确切的起始位置在环形缓冲区中并不重要):



然后,假设将另外两个字节(2&3)添加到环形缓冲区,它们将放在1之后:  



如果删除了两个字节,则环形缓冲区内部的两个最早加入的值将被删除。 环形缓冲区使用FIFO(先进先出)逻辑。 在示例1和2中,第一个进入“环形缓冲区”则第一个被移除,而将3留在缓冲区中。   



如果缓冲区有7个字节,则它已经完全占满:



环形缓冲区的一个特性是,当缓冲区已满并执行后续写入操作时,它将开始覆盖最早的数据。 在当前示例中,添加了两个元素A和B并覆盖了3和4:



最后,如果现在删除了两个字节,则返回的不是3&4而是5&6,因为A&B覆盖了3&4,产生了带有以下内容的缓冲区:  



环形缓冲区使用说明:

环形缓冲区的特性是,在使用环形缓冲区时,不会导致内部数据乱七八糟。 (如果使用了非环形缓冲区,那么在没取一个字节时,就必须对所有字节进行移位。)换句话说,环形缓冲区非常适合作为FIFO(先进先出)缓冲区,而标准缓冲区则适合用作FIFO(先进先出)缓冲区。非环形缓冲区非常适合用作LIFO(后进先出)缓冲区。

对于具有固定最大大小的队列,使用环形缓冲是一种很好的实现策略。如果队列采用最大大小,则环形缓冲区是完全理想的实现;所有队列操作都是固定时间。但是,扩展循环缓冲区需要转移存储器,这是非常耗时和消耗资源的。对于任意扩展的队列,可以首选使用链表方法。

这个是24个字节的环形缓冲区



当写指针即将到达读指针时(由于微处理器没有响应),缓冲区停止记录击键。 在某些计算机上会发出哔声。

这个排版真累人- .-







如果有什么BUG,请自行修复

2021/5/16  源码更新:
[+] 为了大家方便理解新增了Demo


2021/5/15  源码更新:
[!] 修复致命BUG,受影响函数:CircularBufferGetBytes、CircularBufferGetBytesFoIndex、CircularBufferPutToMem、CircularBufferPutBytes
下面为更新后代码:
  
子程序名返回值类型公开备 注
CircularBufferPutToMem整数型 将新的数据复制到环形缓冲区,如果复制的大小超出缓冲区的容量则最早复制的数据将会被覆盖
参数名类 型参考可空数组备 注
lp整数型操作指针
pData整数型
Index整数型pData的偏移值
count整数型需要复制的长度
变量名类 型静态数组备 注
bufferCIRCULARBUFFER_STREAM 
pOld整数型 
srcIndex整数型 
bytesToProcess整数型 
chunk整数型 
如果真 (count ≤ 0)
调试输出 (“计数必须为正。”)
返回 (0)
pOld = _SWAP_CIRCULARBUFFER_STREAM (buffer, lp)
如果真 (buffer.Size + count > buffer.Capacity)
调试输出 (“缓冲区没有足够的容量来放置新项目。”)
_SWAP_CIRCULARBUFFER_STREAM (buffer, pOld)
返回 (0)
InterlockedIncrement (buffer.ref)
srcIndex = Index
bytesToProcess = count
判断循环首 (bytesToProcess > 0)
chunk = 取较小值 (buffer.Capacity - buffer.Tail, bytesToProcess)
RtlMoveMemory (buffer.pBuffer + buffer.Tail, pData + srcIndex, chunk)
判断 (buffer.Tail + chunk = buffer.Capacity)
InterlockedExchange (buffer.Tail, 0)
InterlockedExchangeAdd (buffer.Tail, chunk)
InterlockedExchangeAdd (buffer.Size, chunk)
srcIndex = srcIndex + chunk
bytesToProcess = bytesToProcess - chunk
判断循环尾 ()
CircularBufferFree (lp)
_SWAP_CIRCULARBUFFER_STREAM (buffer, pOld)
返回 (count)
子程序名返回值类型公开备 注
CircularBufferGetBytesFoIndex字节集 从目标缓冲区指定的索引处开始,将指定的字节从对应缓冲区复制取出并删除
参数名类 型参考可空数组备 注
lp整数型操作指针
Index整数型返回的字节集偏移量
count整数型需要复制的长度
变量名类 型静态数组备 注
bufferCIRCULARBUFFER_STREAM 
pOld整数型 
bytesCopied整数型 
dstIndex整数型 
chunk整数型 
arybyte字节集 
pData整数型 
如果真 (Index < 0)
调试输出 (“指定偏移量必须为正 ”)
返回 ({ })
如果真 (count < 0)
调试输出 (“指定的长度必须为正。”)
返回 ({ })
pOld = _SWAP_CIRCULARBUFFER_STREAM (buffer, lp)
如果真 (count > buffer.Size)
调试输出 (“环形缓冲区的内容不足以进行读取/读取操作。”)
_SWAP_CIRCULARBUFFER_STREAM (buffer, pOld)
返回 ({ })
InterlockedIncrement (buffer.ref)
bytesCopied = 0
dstIndex = Index
arybyte = 取空白字节集 (count)
pData = 取指针_字节集型 (arybyte)
判断循环首 (count > 0)
chunk = 取较小值 (buffer.Capacity - buffer.Head, count)
RtlMoveMemory (pData + dstIndex, buffer.pBuffer + buffer.Head, chunk)
判断 (buffer.Head + chunk = buffer.Capacity)
InterlockedExchange (buffer.Head, 0)
InterlockedExchangeAdd (buffer.Head, chunk)
InterlockedExchangeAdd (buffer.Size, -chunk)
dstIndex = dstIndex + chunk
bytesCopied = bytesCopied + chunk
count = count - chunk
判断循环尾 ()
CircularBufferFree (lp)
_SWAP_CIRCULARBUFFER_STREAM (buffer, pOld)
返回 (arybyte)


i支持库列表   支持库注释   
spec特殊功能支持库







补充内容 (2021-5-17 19:39):
经调试发现Server模型里是不会粘包的,如果需要测试可自行将代码模拟成粘包即可
作者: static007    时间: 2021-5-15 18:59

作者: 78226800    时间: 2021-5-15 19:07
谢谢分享!!!
作者: 2995455338    时间: 2021-5-15 19:20
谢谢分享!!!

作者: q1599273319    时间: 2021-5-15 20:34
{:3_42:}{:3_42:}{:3_42:}{:3_42:}
作者: cf2006a    时间: 2021-5-15 23:46
看看 怎么写的!
作者: 599929114    时间: 2021-5-16 00:43
这是一个什么东西啊
作者: 单色    时间: 2021-5-16 01:01
谢谢大佬分享 支持支持
作者: 不苦小和尚    时间: 2021-5-16 05:45
谢谢分享,最近看到了
作者: i77    时间: 2021-5-16 11:20
虽然不知道怎么用 但支持一下
作者: rectdbszy    时间: 2021-5-16 11:38
虽然不知道怎么用 但支持一下
作者: fyh505099    时间: 2021-5-16 11:51
感谢分享 支持一下,虽然还不会用
作者: 天雨时晴    时间: 2021-5-16 12:16
不明觉厉
作者: 枫眼    时间: 2021-5-16 17:37
6666666666666666666666666666666
作者: 轻风影    时间: 2021-5-16 19:11
这个一看就牛B
作者: snak2020    时间: 2021-5-16 19:36
谢谢分享,学习
作者: 361322548    时间: 2021-5-16 20:57
嘿嘿,感谢楼主分享!!...
作者: 懒人定制软件    时间: 2021-5-17 01:01
感谢你的支持,精易有你更精彩  
作者: SD1228    时间: 2021-5-17 02:16
感谢你的支持,精易有你更精彩  
作者: 网络注册会员    时间: 2021-5-17 07:19
精易有你更精彩  
作者: 浅蓝蜗牛    时间: 2021-5-17 09:03
精易有你更精彩  
作者: sinewtec    时间: 2021-5-17 09:07
不明觉厉

作者: 扣扣    时间: 2021-5-17 17:37
感谢楼主的分享,学习一下
作者: 不苦小和尚    时间: 2021-5-17 18:53
学习一下思路,谢谢分享
作者: fusiyon    时间: 2021-5-20 08:22
谢谢分享,学习
作者: 神女软件定制    时间: 2021-6-6 22:53
这不是循环队列嘛
作者: gunan666    时间: 2021-6-7 21:20
        感谢分享,很给力!~
作者: 泪魂    时间: 2021-6-21 17:48
厉害,做的东西很神奇,就很好
作者: 小毛皮    时间: 2021-6-23 21:43
学习一下
作者: 龙猫LM    时间: 2021-6-24 02:49
6+25561561516351053610
作者: 就是那个秋    时间: 2021-6-25 14:26
  感谢分享
作者: Dukes    时间: 2021-6-25 20:36
感谢分享,很给力!~
作者: yj1998    时间: 2021-7-4 06:30
6666666666666
作者: 土豆要不    时间: 2021-7-5 10:00
标题: ++
6666666666666666666
作者: 实力吹逼    时间: 2021-7-6 16:37
66666666666666
作者: 风清云游    时间: 2021-7-15 19:10
好像很厉害的样子  学习一下  支持一个
作者: 土豆要不    时间: 2021-7-17 22:12
标题: ++
6666666666666666666
作者: yi2090    时间: 2021-7-23 08:52
谢谢分享,易语言真方便
作者: a909254    时间: 2021-7-25 14:53
5555555555555
作者: 土豆要不    时间: 2021-7-30 10:00
标题: ++
6666666666666666666
作者: jy3534668    时间: 2021-8-1 14:35
333333333333
作者: qw6677887    时间: 2021-8-2 16:35

感谢大佬分享!!
作者: 阿Q3    时间: 2021-8-3 01:58

康康是不是好东西
作者: Inverse    时间: 2021-8-7 21:10

标示处多了一句错误语句
作者: 土豆要不    时间: 2021-8-8 10:00
标题: ++
6666666666666666666
作者: 阿Q3    时间: 2021-8-8 23:49



感谢分享,很给力!~
作者: 阿Q3    时间: 2021-8-14 00:12
不错,正需要。
作者: yxp123yxp    时间: 2021-8-14 17:36
..................................
作者: 1558302151    时间: 2021-8-20 11:17
得可以的话,请:
附件下载:

Asm汇编插件.zip (1.3 MB, 下载次数: 2448)
作者: qianban    时间: 2021-8-26 21:01
321312312312
作者: shencong    时间: 2021-8-27 09:56
收藏了,以后学习下 (Ps.我和四糸乃贴贴
作者: laosijishare    时间: 2021-9-1 16:55
ZAN                                       
作者: 钢铁璐lu    时间: 2021-10-6 14:37
顶顶顶顶顶顶顶顶顶顶顶顶顶顶顶顶顶顶顶
作者: kaopu666    时间: 2021-10-10 18:41
学习一下英文
作者: By未命名    时间: 2021-10-16 16:31
虽说是易语言,但代码基本是英文,菜鸟看不懂呢
作者: 都由我来赎    时间: 2021-10-30 19:23
大牛 虽然我看不懂先收藏
作者: 1389739946    时间: 2021-10-30 21:26
太棒了QAQ
作者: 小言T默默    时间: 2021-10-31 17:31
不明觉厉 点个赞
作者: 784570816    时间: 2021-11-22 10:29
太棒了QAQ
作者: 1824230500    时间: 2021-12-21 18:09
艾法尔而安排【】【额【】额外【】额外swqewe
作者: GeekCoder    时间: 2022-1-2 09:16
        感谢大佬开源,这个环形缓冲区是真的好用,新技能已get√
作者: beihuo50141011    时间: 2022-1-3 05:20
看起来挺深奥的啊有点似懂非懂了
作者: momoko001    时间: 2022-1-5 08:42
牛逼大神,小弟路过!
作者: kolins007    时间: 2022-1-9 11:03
谢谢楼主分享
作者: 唐山祥子    时间: 2022-1-14 10:50
支持开源~!感谢分享
作者: 土豆要不    时间: 2022-1-18 10:00
标题: ++
6666666666666666666
作者: ocm123    时间: 2022-1-20 01:09
感谢楼主分享
作者: gujinhua    时间: 2022-2-4 01:26
这东西有用,
作者: ghost12    时间: 2022-2-12 04:00
共同努力,共同进步
作者: qq309    时间: 2022-2-18 11:50
多多回复,多多赞币
作者: fjgh    时间: 2022-3-3 09:58
支持开源~!感谢分享
作者: 萌萌哒的新手    时间: 2022-3-6 02:33
很厉害,收下研究了
作者: 樱桃丸子    时间: 2022-3-14 23:50
支持开源~!感谢分享
作者: qt121    时间: 2022-3-19 17:39
666666666666666666666666666666666666666666666666
作者: q3309699299    时间: 2022-3-22 14:10
支持开源~!感谢分享
作者: duisir    时间: 2022-4-2 20:07
66666666666666666666666666666666666
作者: 叫我尹志平    时间: 2022-5-1 14:59
提示: 作者被禁止或删除 内容自动屏蔽
作者: lm88818    时间: 2022-12-1 15:45
支持开源~!感谢分享
作者: yuzhong    时间: 2024-11-10 13:16
1111111111111111111111111111111111111111111111111111
作者: sobcctv    时间: 2025-3-18 23:28
支持一下




欢迎光临 精易论坛 (https://125.confly.eu.org/) Powered by Discuz! X3.4