Condition是Java中用于线程协作的接口,需与Lock配合使用,支持多条件等待和精确唤醒;示例中通过notFull和notEmpty两个Condition实现生产者-消费者模型,相比synchronized+wait/notify,具备可中断、超时等待及更灵活的锁控制优势。

在Java中,Condition 是 java.util.concurrent.locks 包中的一个接口,用于实现线程间的协作通信。它通常配合 Lock 使用,替代传统的 synchronized 和 wait()/notify() 机制,提供更灵活、精细的线程等待与唤醒控制。
Condition 的主要功能是让线程在某个条件不满足时进入等待状态,并在其他线程改变状态后被唤醒。每个 Condition 实例都与一个 Lock 关联,可以看作是“条件队列”。
相比 synchronized 中只能使用单一的 wait/notify,一个 Lock 可以创建多个 Condition,实现多路等待和通知,更加高效。
下面是一个使用 Condition 实现生产者和消费者线程通信的简单例子:
立即学习“Java免费学习笔记(深入)”;
import java.util.LinkedList;
import java.util.Queue;
import java.util.concurrent.locks.Condition;
import java.util.concurrent.locks.Lock;
import java.util.concurrent.locks.ReentrantLock;
public class ProducerConsumer {
private final Queue<Integer> queue = new LinkedList<>();
private final int MAX_SIZE = 5;
private final Lock lock = new ReentrantLock();
private final Condition notFull = lock.newCondition();
private final Condition notEmpty = lock.newCondition();
public void produce(int item) throws InterruptedException {
lock.lock();
try {
while (queue.size() == MAX_SIZE) {
System.out.println("队列已满,生产者等待...");
notFull.await(); // 等待不满
}
queue.offer(item);
System.out.println("生产了: " + item);
notEmpty.signal(); // 通知消费者可以消费
} finally {
lock.unlock();
}
}
public int consume() throws InterruptedException {
lock.lock();
try {
while (queue.isEmpty()) {
System.out.println("队列为空,消费者等待...");
notEmpty.await(); // 等待不空
}
int item = queue.poll();
System.out.println("消费了: " + item);
notFull.signal(); // 通知生产者可以生产
return item;
} finally {
lock.unlock();
}
}
}
在这个例子中:
相比传统的 synchronized + wait/notify,Condition 具有以下优点:
基本上就这些。Condition 提供了比传统方式更强大的线程通信能力,尤其适用于需要精细化控制线程协作的场景。正确使用它能提升程序的并发性能和可维护性。
以上就是Java中Condition实现线程通信方法的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号