这是我的代码:
// in constructor
BlockingQueue queue = new LinkedBlockingQueue();
// later in another thread
Node node = queue.poll(1, TimeUnit.SECONDS);
通常它可以工作,但有时候,在某些情况下(仍然不知道什么时候和为什么)poll()方法不返回NULL,但是将其线程永远保持在WAITING状态。为什么以及如何发生这种情况?
我尝试了ArrayBlockingQueue – 效果相同。我在Mac OS上使用OpenJDK:
java version "1.7.0_05"
Java(TM) SE Runtime Environment (build 1.7.0_05-b06)
Java HotSpot(TM) 64-Bit Server VM (build 23.1-b03, mixed mode)
与Mac OS上的Oracle Java 1.6相同的代码正常工作。这是线程被卡住的地方:
sun.misc.Unsafe.park(Native Method)
java.util.concurrent.locks.LockSupport.park(LockSupport.java:186)
java.util.concurrent.locks.AbstractQueuedSynchronizer.parkAndCheckInterrupt(AbstractQueuedSynchronizer.java:834)
java.util.concurrent.locks.AbstractQueuedSynchronizer.doAcquireInterruptibly(AbstractQueuedSynchronizer.java:894)
java.util.concurrent.locks.AbstractQueuedSynchronizer.acquireInterruptibly(AbstractQueuedSynchronizer.java:1221)
java.util.concurrent.locks.ReentrantLock.lockInterruptibly(ReentrantLock.java:340)
java.util.concurrent.LinkedBlockingQueue.poll(LinkedBlockingQueue.java:462)
有趣的是,当我中断()此线程并尝试轮询()再次,我立即达到相同的情况。