生产者--消费者模式,理解多线程并发

解决生产者消费者的最有效的方式是阻塞队列

举个例子就是一个负责吃,一个负责造,东西放在一张桌子上。

生产者准备食物,如果桌子上已经满了就等待,生产者等待。如果桌子空了的话,消费者等待。这里桌子就是一个共享的对象

生产者消费者模式常用于多线程或者并发代码

优点:

  1.  它简化的开发,你可以独立地或并发的编写消费者和生产者,它仅仅只需知道共享对象是谁
  2. 生产者不需要知道谁是消费者或者有多少消费者,对消费者来说也是一样
  3.  生产者和消费者可以以不同的速度执行
  4.  分离的消费者和生产者在功能上能写出更简洁、可读、易维护的代码
阻塞队列实现生产者消费者模式超级简单,它提供开箱即用支持阻塞的方法put()和take(),开发者不需要写困惑的wait-nofity代码去实现通信。

BlockingQueue 一个接口,Java提供了不同的现实,如ArrayBlockingQueue和LinkedBlockingQueue,两者都是先进先出(FIFO)顺序。

而ArrayLinkedQueue是自然有界的,LinkedBlockingQueue可选的边界。

下面这是一个完整的生产者消费者代码例子,对比传统的wait、nofity代码,它更易于理解

importjava.util.concurrent.BlockingQueue;
importjava.util.concurrent.LinkedBlockingQueue;
importjava.util.logging.Level;
importjava.util.logging.Logger;
 
publicclass ProducerConsumerPattern {
 
    publicstatic void main(String args[]){
 
     //Creating shared object
     BlockingQueue sharedQueue =new LinkedBlockingQueue();
 
     //Creating Producer and Consumer Thread
     Thread prodThread =new Thread(newProducer(sharedQueue));
     Thread consThread =new Thread(newConsumer(sharedQueue));
 
     //Starting producer and Consumer thread
     prodThread.start();
     consThread.start();
    }
 
}
 
//Producer Class in java
classProducer implementsRunnable {
 
    privatefinal BlockingQueue sharedQueue;
 
    publicProducer(BlockingQueue sharedQueue) {
        this.sharedQueue = sharedQueue;
    }
 
    @Override
    publicvoid run() {
        for(inti=0; i<10; i++){
            try{
                System.out.println("Produced: "+ i);
                sharedQueue.put(i);
            }catch (InterruptedException ex) {
                Logger.getLogger(Producer.class.getName()).log(Level.SEVERE,null, ex);
            }
        }
    }
 
}
 
//Consumer Class in Java
classConsumer implementsRunnable{
 
    privatefinal BlockingQueue sharedQueue;
 
    publicConsumer (BlockingQueue sharedQueue) {
        this.sharedQueue = sharedQueue;
    }
 
    @Override
    publicvoid run() {
        while(true){
            try{
                System.out.println("Consumed: "+ sharedQueue.take());
            }catch (InterruptedException ex) {
                Logger.getLogger(Consumer.class.getName()).log(Level.SEVERE,null, ex);
            }
        }
    }
 
}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值