Java多线程相关知识【19】--设计模式--Producer and Consumer设计模式(生产者消费者模式)


菜鸟的一个学习笔记,欢迎大神 批评指正

Java多线程相关知识【19】–设计模式–Producer and Consumer设计模式(生产者消费者模式)

1. 问题的引入

​ 有一个工厂,他负责生产商品,他有很多工人,每天能生产出很多种类的商品,但是,他并不知道客户的消费情况,这也就造成了如果他产能过剩时,他将会有生产浪费的可能。

在Java程序中,若出现这种情况,则会产生内存的使用量过高,甚至有可能产生内存溢出发的可能。

2. 解决的方案

利用中间生产的限额标定,即可解决产能过剩的情况。

3. 代码的实现

货物

/**
 * 货物
 */
public class Production {

    private final String data;

    public Production(String data) {
        this.data = data;
    }

    public String getData() {
        return data;
    }
}

仓库

/**
 * 货物工厂(线程安全)
 */
public class ProductionQueue {
    private final LinkedList<Production> productions;
    private final static int DEFAULT_MAX_PRODUCT_NUM = 100;
    private final int useLimit;


    public ProductionQueue() {
        this(DEFAULT_MAX_PRODUCT_NUM);
    }

    public ProductionQueue(int useLimit) {
        this.productions = new LinkedList<>();
        this.useLimit = useLimit;
    }

    public synchronized void put(Production production) throws InterruptedException {
        while (productions.size()>=useLimit){
            this.wait();
        }
        productions.addLast(production);
        this.notifyAll();
    }

    public synchronized Production take() throws InterruptedException {
        while (productions.isEmpty()){
            this.wait();
        }
        this.notifyAll();
        return productions.removeFirst();
    }

}

生产者

/**
 * 生产者
 */
public class ProductThread extends Thread {
    private final ProductionQueue productionQueue;
    private static int count;
    private final Random random = new Random(System.currentTimeMillis());

    public ProductThread(ProductionQueue productionQueue, int seq) {
        super("PRODUCT"+seq);
        this.productionQueue = productionQueue;
    }

    @Override
    public void run() {
        while (true) {
            try {
                System.out.println(Thread.currentThread().getName() + " set =>" + count);
                productionQueue.put(new Production(Thread.currentThread().getName() + " set =>" + count++));
                Thread.sleep(random.nextInt(1000));
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
        }
    }
}

消费者

/**
 * 消费者
 */
public class ConsumerThread extends Thread {
    private final ProductionQueue productionQueue;

    private final Random random = new Random(System.currentTimeMillis());

    public ConsumerThread(ProductionQueue productionQueue, int seq) {
        super("CONSUMER"+seq);
        this.productionQueue = productionQueue;
    }

    @Override
    public void run() {
        while (true){
            try {
                Production take  = productionQueue.take();
                System.out.println(Thread.currentThread().getName()+" get =>"+take.getData());
                Thread.sleep(random.nextInt(1000));
            } catch (InterruptedException e) {
                break;
            }
        }
    }
}

测试

/**
 * 测试生产消费
 */
public class PCClient {
    public static void main(String[] args) throws InterruptedException {
        //存放仓库
        ProductionQueue productionQueue = new ProductionQueue();
        //生产者
        IntStream.range(0,4).forEach(value ->
        {
            ProductThread productThread = new ProductThread(productionQueue, value);
            productThread.setDaemon(true);
            productThread.start();
        });
        //消费者
        IntStream.range(0,5).forEach(value ->
        {
            ConsumerThread consumerThread = new ConsumerThread(productionQueue, value);
            consumerThread.setDaemon(true);
            consumerThread.start();
        });

        Thread.sleep(60_000L);

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值