admin管理员组

文章数量:1599528

1、生产者消费者模式

生产者和消费者模式:这其实是一个线程同步问题,生产者和消费者共享同一个资源,并且生产者和消费者之间相互依赖,互为条件
对于生产者,仓库未满时,生产产品要放入仓库,继续生产,仓库满时,生产者自己等待,通知消费者消费。
对于消费者,仓库有产品时,从仓库消费产品,继续消费,仓库空时,消费者自己等待,通知生产者生产。
在生产者和消费者问题中,仅有synchronizede是不够的
synchronized可阻止并发更新同一个共享资源,实现了同步
synchronized不能用来实现不同线程之间的消息传递(通信)

线程通信:并发协助模型“生产者/消费者模式”可用Lock+Condition

2、基于Lock+Condition实现生产者消费者模式

Lock类实际上是一个接口,我们在实例化的时候实际上是实例化实现了该接口的类Lock lock = new ReentrantLock();。
Lock类的用法:通过Lock对象lock,用lock.lock来加锁,用lock.unlock来释放锁。在两者中间放置需要同步处理的代码。

2.1、Loc

本文标签: 生产者多线程消费者模式系列