我一直在读关于阻塞队列的文章,出现了一些问题。我读过的所有示例都只演示了只有一个消费者和一个生产者线程的情况。问题是:假设我们有1个生产者和3个消费者,在当前时刻,所有消费者都调用了take()方法,但是队列是空的,所以它们都在等待出现第一个元素。当第一个元素出现时,哪个使用者线程将采用它?哪个消费者线程最先调用了take()?
发布于 2013-04-08 21:49:25
当第一个元素出现时,哪个使用者线程将获取它?哪个消费者线程最先调用了take()?
这与阻塞队列实现以及所讨论的JVM有关,但简短的答案很可能是肯定的。每个线程将在一个条件下等待,当该条件被通知时,等待队列中的第一个线程将被唤醒。
也就是说,您不应该依赖此功能,因为它非常依赖于所讨论的阻塞队列的细节以及JVM和OS版本。
发布于 2013-04-08 21:49:13
我不知道你能不能看出来。真正的问题是:为什么你需要知道?所有的监听器都应该是等价的。由哪一个处理请求并不重要。如果你一定要知道,那就是你错误地设计和实现了它。
发布于 2013-04-08 21:51:59
检查FIFO如果FIFO为true,则按ArrayBlockingQueue(int capacity, boolean fair)顺序处理插入或移除时阻塞的线程的队列访问。
https://stackoverflow.com/questions/15880800
复制相似问题