zoukankan      html  css  js  c++  java
  • java的多生产者多消费者例子

    import java.util.concurrent.locks.*;


    public class Test9 {

    public static void main(String[] args) {
    // TODO 自动生成的方法存根
    Resource r=new Resource();
    Producer p=new Producer(r);
    Consumer c=new Consumer(r);
    Thread t0=new Thread(p);
    Thread t1=new Thread(p);
    Thread t2=new Thread(c);
    Thread t3=new Thread(c);
    t0.start();
    t1.start();
    t2.start();
    t3.start();
    }

    }

    class Resource
    {
    private String name;
    private int count=1;
    private boolean flag;

    //创建一个锁对象。
    Lock lock ;
    //通过已有的锁获取两组监视器对象,一组监视生产者,一组监视消费者。
    Condition producer_con ;
    Condition consumer_con ;
    public Resource()
    {
    this.lock= new ReentrantLock();
    this.producer_con = lock.newCondition();
    this.consumer_con = lock.newCondition();
    }

    public void set(String name)
    {
    lock.lock();
    try {
    while(flag)
    producer_con.await();
    this.name=name+count;
    count++;
    System.out.println(Thread.currentThread().getName()+"....生产者..."+this.name);
    flag=true;
    consumer_con.signal();
    } catch (InterruptedException e) {
    // TODO 自动生成的 catch 块
    e.printStackTrace();
    }finally{
    lock.unlock();
    }
    }
    public void get()
    {
    lock.lock();
    try {
    while(!flag)
    consumer_con.await();
    System.out.println(Thread.currentThread().getName()+"....消费者......."+this.name);
    flag=false;
    producer_con.signal();
    } catch (InterruptedException e) {
    // TODO 自动生成的 catch 块
    e.printStackTrace();
    }finally{
    lock.unlock();
    }

    }
    }
    class Producer implements Runnable
    {

    Resource r=null;
    public Producer(Resource r)
    {
    this.r=r;
    }
    public void run() {
    // TODO 自动生成的方法存根
    while(true)
    r.set("烤鸭");
    }

    }

    class Consumer implements Runnable
    {

    Resource r=null;
    public Consumer(Resource r)
    {
    this.r=r;
    }
    public void run() {
    // TODO 自动生成的方法存根
    while(true)
    r.get();
    }
    }

  • 相关阅读:
    Scala基础(1)
    简单模拟flume
    朴素贝叶斯
    关于hive的优化
    Hive的一些理解
    Flume的简单理解
    tiny-Spring【2】逐步step分析-新加入特性
    前、中、后缀表达式【待完成】
    奇妙的算法【9】YC每个小孩的糖果数,找公约数,最少硬币数
    奇妙的算法【8】筹钱种数、定时找出最高频次的数据、三子棋落点判断
  • 原文地址:https://www.cnblogs.com/ql211lin/p/3975945.html
Copyright © 2011-2022 走看看