并发无锁队列学习之一【开篇】

简介:

1、前言

  

  队列在计算机中非常重要的一种数据结构,尤其在操作系统中。队列典型的特征是先进先出(FIFO),符合流水线业务流程。在进程间通信、网络通信之间经常采用队列做缓存,缓解数据处理压力。结合自己在工作中遇到的队列问题,总结一下对不同场景下的队列实现。根据操作队列的场景分为:单生产者——单消费者、多生产者——单消费者、单生产者——多消费者、多生产者——多消费者四大模型。其实后面三种的队列,可以归纳为一种多对多。根据队列中数据分为:队列中的数据是定长的、队列中的数据是变长的。

2、队列操作模型

(1)单生产者——单消费者

(2)多生产者——单消费者

(3)单生产者——多消费者

(4)多生产者——多消费者

3、队列数据定长与变长

(1)队列数据定长

(2)队列数据变长

4、并发无锁处理

(1)单生产者——单消费者模型

  此种场景不需要加锁,定长的可以通过读指针和写指针进行控制队列操作,变长的通过读指针、写指针、结束指针控制操作。具体实现可以参考linux内核提供的kfifo的实现。可以参考:http://blog.csdn.net/linyt/article/details/5764312

(2)(一)多对多(一)模型

  正常逻辑操作是要对队列操作进行加锁处理。加锁的性能开销较大,一般采用无锁实现。无锁实现原理是CAS、FAA等机制。定长的可以参考:

http://www.searchtb.com/2012/10/introduction_to_disruptor.html

http://coolshell.cn/articles/8239.html

变长的可以参考intel dpdk提供的rte_ring的实现。http://blog.csdn.net/linzhaolover/article/details/9771329

相关文章
|
5月前
|
存储 安全 容器
【多线程面试题二十一】、 分段锁是怎么实现的?
这篇文章解释了分段锁的概念和实现方式,通过将数据分成多个段并在每段数据上使用独立锁,从而降低锁竞争,提高并发访问效率,举例说明了`ConcurrentHashMap`如何使用分段锁技术来实现高并发和线程安全。
【多线程面试题二十一】、 分段锁是怎么实现的?
|
8月前
|
算法 Go 调度
goroutine源码分析,直击并发底层实现
goroutine源码分析,直击并发底层实现
77 0
|
存储 缓存 算法
Java多线程与并发-原理
Java多线程与并发-原理
66 0
|
安全 Java Spring
并发编程-01并发初窥
并发编程-01并发初窥
97 0
|
缓存 Java 编译器
阿里巴巴面试题- - -多线程&并发篇(三十八)
阿里巴巴面试题- - -多线程&并发篇(三十八)
阿里巴巴面试题- - -多线程&并发篇(三十六)
阿里巴巴面试题- - -多线程&并发篇(三十六)
阿里巴巴面试题- - -多线程&并发篇(三十七)
阿里巴巴面试题- - -多线程&并发篇(三十七)
|
存储 自然语言处理 Oracle
阿里巴巴面试题- - -多线程&并发篇(三十二)
阿里巴巴面试题- - -多线程&并发篇(三十二)
|
Java 关系型数据库 数据库
阿里巴巴面试题- - -多线程&并发篇(四十二)
阿里巴巴面试题- - -多线程&并发篇(四十二)
|
Java 开发者
阿里巴巴面试题- - -多线程&并发篇(三十九)
阿里巴巴面试题- - -多线程&并发篇(三十九)

热门文章

最新文章

相关实验场景

更多