首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >实现可变大小的环形缓冲区?

实现可变大小的环形缓冲区?
EN

Stack Overflow用户
提问于 2019-06-30 04:49:38
回答 2查看 397关注 0票数 0

我已经理解了环形缓冲区背后的想法,以及它如何帮助不必在过程中移动元素。然而,我很好奇如何最好地处理线程安全的可变长度缓冲区,并提供与环形缓冲区类似的优点?我们是否可以在达到容量时将大小加倍,并让一个线程在互斥锁中执行复制?这个可变大小的缓冲区仅仅是一个实现为线程安全的队列吗?最好的方法是什么,这种并发读/写访问的替代解决方案的优缺点是什么?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2019-06-30 06:19:56

对于多线程生产者/消费者应用程序,当您需要它增长时,单个循环缓冲区通常不再是一个好主意。

我通常会切换到固定大小的单次使用FIFO缓冲区的无锁单链表,其中有未使用的缓冲区,可以回收存储在无锁堆栈中。

这里的非阻塞队列非常简单实用:https://www.cs.rochester.edu/u/scott/papers/1996_PODC_queues.pdf

票数 2
EN

Stack Overflow用户

发布于 2019-06-30 06:09:20

链表可能更好,因为在扩展环形缓冲区时不需要复制。

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/56820789

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档