ArrayBlockingQueue是一个基于数组实现的有界阻塞队列,设计目的是为了支持多线程环境下的
生产者-消费者模式
特点
- 数组指定大小后,不会动态扩容
- 队列满了想要往队列中添加元素的线程都会被阻塞,直到消费者消费后队列有空位
- 默认使用的是ReentrantLock的非公平锁
- 生产者和消费者共用同一把锁
- 设置了两个等待队列条件:notEmpty(队列是否为空),notFull(队列是否已满)
- 两个条件对应了两个不同的等待队列
- 队列为空,线程被放入notEmpty(消费者条件等待队列),消费者阻塞等待获取队列中的元素
- 队列已满,线程被放入notFull(生产者条件等待队列),生产者阻塞等待将元素放入队列
- 线程在获取锁的过程中被中断了,会处理中断(可能会抛异常)
添加弹出流程
添加或者获取完元素后,需要手动释放锁(在finally中)
put(E e)
take()