Java实现生产者消费者

问题描述

生产者和消费者在同一时间段内共用同一个存储空间,生产者向存储空间中添加产品,消费者从存储空间中取走产品,当存储空间为空时,消费者阻塞,当存储空间满时,生产者阻塞。

当不加以协调时,可能会出现死锁。存储空间已满,而生产者占用着它,消费者等待生产者让出空间从而取走产品,生产者等待消费者消费产品,从而向空间中添加产品。

01 wait和notify实现

02 await和signal实现 ReentranLock

03 阻塞队列实现

三种方法原理一致,都是对独占空间加锁,阻塞和唤醒线程。第一种比较传统,第三种最简单。只需存储和使用,线程同步的事情交由LinkedBlockingQueue实现。

转载于:https://my.oschina.net/u/3938912/blog/3084644

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值