我查看了java.uti.concurrent.locks.AbstractQueuedSynchronizer的源代码,acquire()方法看起来像这样-
public final void acquire(int arg) {
if (!tryAcquire(arg) &&
acquireQueued(addWaiter(Node.EXCLUSIVE), arg))
Thread.currentThread().interrupt();
}为什么它会中断线程调用acquire()?如果线程run()方法中的某个地方有检查,那么它可能会在调用acquire()之后通过,这可能是不希望的,也是没有想到的?
有没有人愿意解释一下上面这段代码为什么会这样?
发布于 2008-10-16 09:44:34
如果您阅读了acquiredQueued的Javadoc,您会注意到,如果线程在等待时被中断,它将返回true。因此,对selfInterrupt (在OpenJDK源代码中调用它)的调用是为了将中断传播到调用线程,否则它将被吞噬。
https://stackoverflow.com/questions/207946
复制相似问题