Java实现生产者消费者模型有三种核心方式:一是用阻塞队列(如ArrayBlockingQueue),自动处理满/空阻塞,无需手动同步;二是用synchronized+wait/notify,需在同步块中用while循环防虚假唤醒并调用notifyAll;三是用Lock+Condition,可精准唤醒生产或消费线程。
Java中实现生产者消费者模型,核心是解决多线程对共享资源的协同访问:生产者往缓冲区放数据,消费者从缓冲区取数据,二者需避免重复操作、空取、满写,并保证线程安全。关键不在“写多少代码”,而在理清协作逻辑和同步边界。
Java并发包提供了线程安全的阻塞队列(如 ArrayBlockingQueue、LinkedBlockingQueue),内部已封装 wait/notify 和锁机制,自动处理“满时阻塞生产”“空时阻塞消费”,大幅降低出错概率。
new ArrayBlockingQueue(10) ),容量即缓冲区大小
者调用 queue.put(item):队列满则自动等待;消费者调用 queue.take():队列空则自动等待若想深入掌握线程协作本质,可手动实现:定义共享缓冲区(如 List)、用 synchronized 锁住临界区,再配合 wait() 释放锁并等待,notifyAll() 唤醒所有等待线程。
IllegalMonitorStateException
while (list.size() == MAX)),而非 if —— 防止虚假唤醒notifyAll()(不是 notify),确保不遗漏该被唤醒的某一方相比 synchronized,ReentrantLock 配合 Condition 可为“生产等待”和“消费等待”分别定义条件变量,避免 notifyAll 的“惊群效应”,唤醒更精准。
notFull = lock.newCondition() 和 notEmpty = lock.newCondition()
notFull.await(),成功放入后 notEmpty.signal()
notEmpty.await(),成功取出后 notFull.signal()
真实场景中,仅实现基础协作远远不够:
不复杂但容易忽略。选对工具(优先阻塞队列),守住同步边界(锁+条件判断),再补上停止和异常逻辑,一个健壮的生产者消费者就落地了。