Lock锁 实现生产者和消费者问题
来源:互联网 发布:网络id 编辑:程序博客网 时间:2024/05/20 20:57
商品类:
package com.thread.lock;import java.util.concurrent.locks.Condition;import java.util.concurrent.locks.Lock;import java.util.concurrent.locks.ReentrantLock;/*Lock Condition *noctiyAll() 唤醒所有线程 其中 唤醒自己一方的线程没有意义 唤醒全部线程又太浪费资源 *只唤醒 对方线程是最好的选择 那么如何仅唤醒对方的线程? * JDK1.5的锁机制 * */public class Good {private String name;private int count = 0;private boolean flag = false;// 没有商品// Lock 替代了同步机制// 定义一个锁Lock lock = new ReentrantLock();// Condition Condition 将 Object 监视器方法(wait、notify 和// notifyAll)分解成截然不同的对象,以便通过将这些对象与任意 Lock 实现组合使用// 返回一个Condition 对象Condition prc = lock.newCondition();//生产派Condition cus = lock.newCondition();//消费派public void set(String name) {// 进来上锁lock.lock();while (flag) {// 有商品 一次不成立 上来就生产try {// 生产者 conditionprc.await();// Thread.sleep(1000);} catch (InterruptedException e) {// TODO Auto-generated catch blocke.printStackTrace();}}this.name = name + "..." + (count++);System.out.println(Thread.currentThread().getName() + "-----生产了-----"+ this.name);flag = true;// 唤醒的是消费者 唤醒一个 signalcus.signal();// 出同步之前解锁lock.unlock();}public void get() {lock.lock();while (!flag) {// 没有商品 第一次上来就等待try {cus.await();// Thread.sleep(50);} catch (InterruptedException e) {// TODO Auto-generated catch blocke.printStackTrace();}}System.out.println(Thread.currentThread().getName() + "====消费了====="+ this.name);flag = false;prc.signal();lock.unlock();}}
生产者:
package com.thread.lock;public class Procuder implements Runnable {private Good good;public Procuder(Good good) {super();this.good = good;}@Overridepublic void run() {while (true) {good.set("商品");}}}
消费者:
package com.thread.lock;public class Customer implements Runnable {private Good good;public Customer(Good good) {super();this.good = good;}@Overridepublic void run() {while (true) {good.get();}}}
测试类:
package com.thread.lock;public class Test {public static void main(String[] args) {Good good = new Good();Procuder p = new Procuder(good);Customer c = new Customer(good);Thread t1 = new Thread(p);Thread t2 = new Thread(c);Thread t3 = new Thread(p);Thread t4 = new Thread(c);t1.start();t2.start();t3.start();t4.start();}}
0 0
- Lock锁 实现生产者和消费者问题
- 使用Lock来实现生产者和消费者问题
- 使用Lock来实现生产者和消费者问题
- 使用Lock来实现生产者和消费者问题
- 使用Lock来实现生产者和消费者问题
- 使用Lock来实现生产者和消费者问题
- 使用Lock来实现生产者和消费者问题
- Lock锁机制和synchronize分别实现生产者消费者例程
- Synchroniazed和Lock实现生产者--消费者
- 经典问题之生产者-消费者问题——Lock实现
- synchronized与Lock 的区别&分别实现生产者/消费者问题
- 使用Lock和Condition实现生产者和消费者
- 使用Lock和Condition实现生产者消费者模型
- 生产者消费者模型(多个生产者和多个消费者)JDK1.5 (Lock&Condition)实现版
- 多线程-生产者消费者lock锁
- Java多线程-Lock锁的使用,以及生产者和消费者的实现
- 用java实现生产者和消费者问题
- Java实现生产者和消费者问题
- 开发一个Windows版的hello world
- 开源分布式存储系统介绍
- jQuery弹出框在iframe无法正常使用的解决方式
- python进阶(4) getattr的用法
- SpringMVC+hibernate+mysql中要注意的问题——特别是注释的问题
- Lock锁 实现生产者和消费者问题
- 死锁问题
- android:为TextView添加样式——下划线,颜色,设置链接样式及前背景色
- django中的meta参数
- flex application/group addChild失败
- vmware-vdiskmanager使用详解,vmware linux系统磁盘扩容,合并多个磁盘文件
- TCP建立和关闭过程
- java入门学习(十七) 递归
- 开机后USB鼠标拔插一次才能使用排查方法