• 生产者消费者模型


    1.篮子

    package queue.test;
    
    import java.util.concurrent.BlockingQueue;
    import java.util.concurrent.LinkedBlockingQueue;
    
    public class Basket {
    
        BlockingQueue<String> basket = new LinkedBlockingQueue<String>(3);
        
        public void produce() throws InterruptedException
        {
            basket.put("apple");
        }
        
        public String consume() throws InterruptedException
        {
            return basket.take();
        }
    }

    2.生产者

    package queue.test;
    
    public class Producer implements Runnable{
    
        private String instance;
        private Basket basket;
    
        public Producer(String instance, Basket basket) {
            super();
            this.instance = instance;
            this.basket = basket;
        }
    
        @Override
        public void run() {
            // TODO Auto-generated method stub
            while(true)
            {
                System.out.println("produce apple start-"+instance);
                try 
                {
                    basket.produce();
                    System.out.println("produce apple end-"+instance);
                    Thread.sleep(300);
                } catch (InterruptedException e) {
                    // TODO Auto-generated catch block
                    e.printStackTrace();
                }
            }
        }
    
    }

    3.消费者

    package queue.test;
    
    public class Consumer implements Runnable{
    
        private String instance;
        private Basket basket;
        
        public Consumer(String instance, Basket basket) {
            super();
            this.instance = instance;
            this.basket = basket;
        }
    
        @Override
        public void run() {
            // TODO Auto-generated method stub
            while(true)
            {
                System.out.println("consumer start-"+instance);
                try {
                    basket.consume();
                    
                    System.out.println("consumer end-"+instance);
                    
                    Thread.sleep(1000);
                } catch (InterruptedException e) {
                    // TODO Auto-generated catch block
                    e.printStackTrace();
                }
            }
        }
    
    }

    3.测试

    package queue.test;
    
    import java.util.concurrent.ExecutorService;
    import java.util.concurrent.Executors;
    
    public class QueueTest {
    
        public static void main(String[] args) {
            Basket basket = new Basket();
            
            Producer p1 = new Producer("p1", basket);
            Producer p2 = new Producer("p2", basket);
            Consumer c = new Consumer("c1", basket);
            
            ExecutorService pool = Executors.newCachedThreadPool();
            pool.submit(p1);
            pool.submit(p2);
            pool.submit(c);
        }
    
    }
  • 相关阅读:
    Dapper ORM 用法—Net下无敌的ORM(转)
    微軟将从 .NET 4 以后的版本弃用 System.Data.OracleClient 以及Oracle 的各种连接方法
    最火的.NET开源项目
    sql日期格式化
    项目失败总结
    C#,往线程里传参数的方法总结
    线程的几种用法
    小程序api-01-abcdefg
    cnpm
    关于mpvue和wafer2-client-sdk的 微信登录失败,请检查网络状态
  • 原文地址:https://www.cnblogs.com/Android9527/p/5407340.html
Copyright © 2020-2023  润新知