线程-线程协作-管程法

wait()让线程堵塞;
notifyAll()通知线程接触堵塞

mq 的思想,

列: 生产者生产,消费者消费,通过缓冲区

生产者生产100个摸头,消费者买馒头。 消费者从缓冲区取馒头,如果馒头已卖完,就进入等待,等生产者做馒头,放到容器里,再通知消费者取馒头,如果生产者已经再容器里生产100个 则 进入等待,直到有消费者消费馒头,然后通知生产者解除等待

/**
 * 协作模型:生产者消费者实现方式一:管程法
 * 借助缓冲区
 * 
 * @author
 *
 */
public class CoTest01 {
   public static void main(String[] args) {
      SynContainer container = new SynContainer();
      new Productor(container).start();
      new Consumer(container).start();
   }
}
//生产者
class Productor extends Thread{
   SynContainer container  ;  
   public Productor(SynContainer container) {
      this.container = container;
   }

   public void run() {
      //生产
      for(int i=0;i<100;i++) {
         System.out.println("生产-->"+i+"个馒头");
         container.push(new Steamedbun(i) );
      }
   }
}
//消费者
class Consumer extends Thread{
   SynContainer container  ;  
   public Consumer(SynContainer container) {
      this.container = container;
   }
   public void run() {
      //消费
      for(int i=0;i<100;i++) {
         System.out.println("消费-->"+container.pop().id+"个馒头");
      }
   }
}
//缓冲区
class SynContainer{
   Steamedbun[] buns = new Steamedbun[10]; //存储容器
   int count = 0; //计数器
   //存储 生产
   public synchronized void push(Steamedbun bun) {
      //何时能生产  容器存在空间
      //不能生产 只有等待
      if(count == buns.length) {
         try {
            this.wait(); //线程阻塞  消费者通知生产解除
         } catch (InterruptedException e) {
         }
      }
      //存在空间 可以生产
      buns[count] = bun;
      count++;
      //存在数据了,可以通知消费了
      this.notifyAll();
   }
   //获取 消费
   public synchronized Steamedbun pop() {
      //何时消费 容器中是否存在数据
      //没有数据 只有等待
      if(count == 0) {
         try {
            this.wait(); //线程阻塞  生产者通知消费解除
         } catch (InterruptedException e) {
         }
      }
      //存在数据可以消费
      count --;
      Steamedbun bun = buns[count] ;    
      this.notifyAll(); //存在空间了,可以唤醒对方生产了
      return bun;
   }
}
//馒头
class Steamedbun{
   int id;
   public Steamedbun(int id) {
      this.id = id;
   }
   
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值