BlockingQueue接口主要用于解决生产者-消费者问题。 当从队列中获取或移除元素时,如果队列为空,需要等待,直到队列不空;同时如果向队列中添加元素时,如果队列无可用空间,也需要等待。
BlockingQueue的实现是线程安全的,如果你试图向队列中存入null将抛出异常。它的实现类包括ArrayBlockingQueue,LinkedBlockingQueue,PriorityBlockingQueue,DelayQueue :
ArrayBlockingQueue:基于数组实现的一个阻塞队列,在创建ArrayBlockingQueue对象时必须制定容量大小。并且可以指定公平性与非公平性,默认情况下为非公平的,即不保证等待时间最长的队列最优先能够访问队列。
LinkedBlockingQueue:基于链表实现的一个阻塞队列,在创建LinkedBlockingQueue对象时如果不指定容量大小,则默认大小为Integer.MAX_VALUE。
PriorityBlockingQueue:以上2种队列都是先进先出队列,而PriorityBlockingQueue却不是,它会按照元素的优先级对元素进行排序,按照优先级顺序出队,每次出队的元素都是优先级最高的元素。注意,此阻塞队列为无界阻塞队列,即容量没有上限(通过源码就可以知道,它没有容器满的信号标志),前面2种都是有界队列。
DelayQueue:基于PriorityQueue,一种延时阻塞队列,DelayQueue中的元素只有当其指定的延迟时间到了,才能够从队列中获取到该元素。DelayQueue也是一个无界队列,因此往队列中插入数据的操作(生产者)永远不会被阻塞,而只有获取数据的操作(消费者)才会被阻塞。
几个重要方法:
· put(E e): 向队列中插入元素,如果队列已满,则需要等待
· E take(): 从队列头部获取并移除元素,如果队列为空则需要等待可用的元素
以下使用ArrayBlockingQueue来实现。
|
|