用 Java 实现生产者和消费者的三种方法

生产者消费者问题是多线程的一个经典问题,它描述是有一块缓冲区做为仓库,生产者能够将产品放入仓库,消费者则能够从仓库中取走产品。安全

在Java中有四种方法支持同步,其中前三个是同步方法,一个是管道方法。多线程

  • wait() / notify()方法
  • await() / signal()方法
  • BlockingQueue阻塞队列方法

 

wait() / notify()方法

wait() / nofity()方法是基类Object的两个方法:并发

  • wait()方法:当缓冲区已满/空时,生产者/消费者线程中止本身的执行,放弃锁,使本身处于等等状态,让其余线程执行。
  • notify()方法:当生产者/消费者向缓冲区放入/取出一个产品时,向其余等待的线程发出可执行的通知,同时放弃锁,使本身处于等待状态。

 

await() / signal()方法

await()和signal()的功能基本上和wait() / nofity()相同,彻底能够取代它们,可是它们和新引入的锁定机制 Lock 直接挂钩,具备更大的灵活性。经过在Lock对象上调用newCondition()方法,将条件变量和一个锁对象进行绑定,进而控制并发程序访问竞争资源的安全。spa

 

BlockingQueue

它是一个已经在内部实现了同步的队列,实现方式采用的是咱们第2种await() / signal()方法。它能够在生成对象时指定容量大小。它用于阻塞操做的是put()和take()方法:线程

put()方法:相似于咱们上面的生产者线程,容量达到最大时,自动阻塞。对象

take()方法:相似于咱们上面的消费者线程,容量为0时,自动阻塞。队列

相关文章
相关标签/搜索