什么叫做阻塞队列的有界和无界

阻塞队列

阻塞队列,是一种特殊的队列,它在普通队列的基础上提供了两个附加功能:
  • 当队列为空的时候,获取队列中元素的消费者线程会被阻塞,同时唤醒生产者线程。
  • 当队列满了的时候,向队列中添加元素的生产者线程被阻塞,同时唤醒消费者线程。
什么叫做阻塞队列的有界和无界_第1张图片

有界队列

阻塞队列中能够容纳的元素个数,通常情况下是有界的,比如我们实例化一个 ArrayBlockingList,可以在构造方法中传入一个整形的数字,表示这个基于数组的阻塞队列中能够容纳的元素个数。这种就是有界队列。

无界队列

而无界队列,就是没有设置固定大小的队列,不过它并不是像我们理解的那种元素没有任何限制,而是它的元素存储量很大,像 LinkedBlockingQueue,它的默认队列长度是 Integer.Max_Value,所以我们感知不到它的长度限制。

安全性

无界队列存在比较大的潜在风险,如果在并发量较大的情况下,线程池中可以几乎无限制的添加任务,容易导致内存溢出的问题!

你可能感兴趣的:(java面试题,1024程序员节,java)