操作系统 - 使用google guava库Monitor 解决消费者问题

1.成员:
生产者、缓冲区、消费者

2.引入jar包
guava-23.0.jar

3.代码

package monitor;

import com.google.common.util.concurrent.ListeningExecutorService;
import com.google.common.util.concurrent.Monitor;
import com.google.common.util.concurrent.MoreExecutors;

import java.util.ArrayList;
import java.util.LinkedList;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import java.util.concurrent.atomic.AtomicInteger;

/*
 * 用google guava库Monitor 写消费者问题
 */
 
public class MonitorDemo {
    private LinkedList<Integer> buffer= new LinkedList<>() ;
    private static final int MAX = 10 ;
    //记录生产的数据编号
    private static AtomicInteger count = new AtomicInteger(0) ;
    //int i ;  i++ ;非原子性操作 ;  i++ 拆分成多行 ;线程安全问题
    private Monitor monitor = new Monitor() ;

    //生产数据
    public void produce(int value){
		//一般方法
		// if(buffer.size()<MAX)
			// notifyALL();  若小于MAX,就唤醒消费者
		// else 
			// wait();
		
        try {
				
            //enterWhen:相当于加锁
            monitor.enterWhen( monitor.newGuard(  ()->  buffer.size()<MAX        )    ) ;
            buffer.addLast( value);
        } catch (InterruptedException e) {
            e.printStackTrace();
        }finally{
            monitor.leave();
            System.out.println("生产完毕,缓冲区大小:" + buffer.size());
        }
    }

    //消费数据
    public int consume(){
        try {
            monitor.enterWhen(  monitor.newGuard(  ()-> ! buffer.isEmpty()      )      );
           return  buffer.removeFirst()  ;
        } catch (InterruptedException e) {
            e.printStackTrace();
            throw new RuntimeException(e) ;
        }finally {
            monitor.leave();
            System.out.println("消费完毕,缓冲区大小:" + buffer.size());
        }
    }

    public static void main(String[] args) {
        MonitorDemo demo = new MonitorDemo() ;

		//原生线程池
        ExecutorService executorService = Executors.newFixedThreadPool(6);
        //将线程池包装
        ListeningExecutorService listeningExecutorService = MoreExecutors.listeningDecorator(executorService);

		//向线程池放入3个生产者
        for(int i=0;i<3;i++){
            listeningExecutorService.submit( () ->{
                while(true){
                  int result =   count.getAndIncrement(); //i++  0  1  2
                  demo.produce( result );
                    System.out.println("生产:"+ result);
                }

            }          ) ;
        }
        //向线程池放入3个消费者
        for(int i=0;i<3;i++){
            while(true){
               int result =  demo.consume() ;
                System.out.println("消费" +result);
            }
        }
    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值