gpt4 book ai didi

java - 如何确定条件变量上等待时间最长的线程?

转载 作者:行者123 更新时间:2023-12-02 09:25:07 24 4
gpt4 key购买 nike

我从可重入锁创建了一个条件变量,并将公平参数设置为 true。我的应用程序中的条件变量有多个等待线程。我在文档中读到,如果我调用 signal 方法,最长等待的线程将首先收到信号。我想知道唤醒线程的条件是否不成立,并且他再次调用await,其等待时间是否会重置或继续累积。

private ReentrantLock lock = new ReentrantLock(true);
private Condition condition = lock.newCondition();

lock.lock();
while (!isAllowedToProceed){
condition.await();
}
lock.unlock();

最佳答案

等待时间是线程当前等待的时间。它不包括任何先前的等待。您可以将其视为 FIFO 队列。

关于java - 如何确定条件变量上等待时间最长的线程?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58397422/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com