Java中是否会发生虚假唤醒?
看到各种与锁定相关的问题,并且(几乎)总是发现“由于虚假唤醒而引起的循环” 1我想知道,有人经历过这种唤醒(例如,假设硬件/软件环境不错)吗?
我知道“虚假”一词没有明显的原因,但是发生此类事件的原因可能是什么?
(1注意:我不是在问循环练习。)
编辑:一个帮助器问题(对于那些喜欢代码示例的人):
如果我有以下程序,并且运行它:
public class Spurious { public static void main(String[] args) {
Lock lock = new ReentrantLock();
Condition cond = lock.newCondition();
lock.lock();
try {
try {
cond.await();
System.out.println("Spurious wakeup!");
} catch (InterruptedException ex) {
System.out.println("Just a regular interrupt.");
}
} finally {
lock.unlock();
}
}
}
我该怎么做才能await
虚假地唤醒它,而不必永远等待随机事件?
回答:
pthread_cond_wait()
Linux中的功能是使用futex系统调用实现的。EINTR当进程接收到信号时,Linux上的每个阻塞系统调用都会突然返回。… pthread_cond_wait()
无法重新开始等待,因为它可能会在futex
系统调用之外的短暂时间内错过一次真正的唤醒。只能通过调用方检查不变性来避免这种竞争状态。因此,POSIX信号将产生伪唤醒。
简介:如果发出Linux进程信号,则其等待线程将各自享受良好的热虚假唤醒。
以上是 Java中是否会发生虚假唤醒? 的全部内容, 来源链接: utcz.com/qa/421472.html