当前位置:   article > 正文

阻塞队列被异步消费怎么保持顺序_java 阻塞队列异步消费如何保持顺序

java 阻塞队列异步消费如何保持顺序

阻塞队列

阻塞队列本身是符合 FIFO(先进先出) 特性的队列,也就是存储进去的元素符合先进先出的规则。其次,在阻塞队列里面,使用了 condition 条件等待来维护了两个等待队列(如图),一个是队列为空的时候存储被阻塞的消费者, 另一个是队列满了的时候存储被阻塞的生产者 并且存储在等待队列里面的线程,都符合 FIFO 的特性。

消费过程

最后,对于阻塞队列的消费过程,有两种情况:

  • 第一种,就是阻塞队列里面已经包含了很多任务,这个时候启动多个消费者去消费的时候,它的有序性保证是通过加锁来实现的,也就是每个消费者线程去阻塞队列获取任务的时候 必须要先获得排他锁。
  • 第二种,如果有多个消费者线程因为阻塞队列中没有任务而阻塞,这个时候这些线程是按照 FIFO 的顺序存储到condition 条件等待队列中的。 当阻塞队列中开始有任务要处理的时候,这些被阻塞的消费者线程会严格按照 FIFO 的顺序来唤醒,从而保证了消费的顺序型。
声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/码创造者/article/detail/920454
推荐阅读
相关标签
  

闽ICP备14008679号