在介绍阻塞队列之前我们先看下一下什么是生产者消费者模型:
生产者消费者模型就是通过一个容器来解决生产者和消费者的强耦合问题,生产者和消费者不直接进行通信,而是通过阻塞队列来进行通信,所以生产者生产完数据不用等待消费者进行处理,直接扔给阻塞队列,消费者需要数据不找生产者直接从阻塞队列里取。
举个列子:
A请求暴涨,所以阻塞队列请求暴涨,由于阻塞队列没啥计算量 就是只是单纯存个数据 能抗住压力
B也可以按照之前的速度来消费,不会因为A而引起崩溃。
阻塞队列除了解决线程安全问题之外还可以产生阻塞效果:
1)如果队列为空,尝试出队列,就会出现阻塞 ,阻塞到队列不为空位置。
2.如果队列为满,尝试入队列,也会出现阻塞,阻塞到队列不为满为止。
阻塞队列的实现:
java标准库阻塞队列的实现
如何实现我们自己的阻塞队列呢?
1、首先我们要实现一个循环队列,什么是循环队列?
简单说一下循环队列,在一个普通队列上,设置一个head和tile 分别代表头和尾,一旦队列中插入元素,tile++,队列中的元素出去,就head++(出的是head位置的元素)