BlockingQueue的阻塞策略有以下几种:
ArrayBlockingQueue:基于数组实现的有界阻塞队列,当队列满时,生产者阻塞直到队列有空间;当队列为空时,消费者阻塞直到队列有元素。
LinkedBlockingQueue:基于链表实现的有界或无界阻塞队列,其内部实现了两个锁分别用于生产者和消费者的阻塞操作。
PriorityBlockingQueue:基于优先级堆实现的无界阻塞队列,元素按照优先级顺序出队,插入时会调整堆结构。
SynchronousQueue:不存储元素的阻塞队列,生产者线程插入一个元素后会被阻塞,直到有消费者线程取出该元素。
DelayQueue:延迟队列,元素必须实现Delayed接口,元素只有在延迟时间到达时才能被消费。
LinkedTransferQueue:基于链表的无界阻塞队列,添加了一些额外的方法,如tryTransfer()和tryTransfer(E e, long timeout, TimeUnit unit)。
LinkedBlockingDeque:基于链表的阻塞双端队列,可以在队列的两端进行操作,也可以设置容量限制。