使用BlockingQueue实现的生产者和消费者

使用Java BlockingQueue实现的生产者和消费者

1.定义生产者


class Producer implements Runnable {

    private BlockingQueue<String> queue;
    private String id;

    private volatile boolean isRunning = true;
    private static AtomicInteger count = new AtomicInteger();

    public Producer(BlockingQueue<String> queue, String id) {
        this.queue = queue;
        this.id = id;
    }

    public void stop() {
        isRunning = false;
    }

    @Override
    public void run() {

        String data = null;
        try {
            while (isRunning) {
                System.out.println("PRODUCER: " + id + " is running");
                Thread.sleep(100);

                data = "data:" + count.incrementAndGet();
                System.out.println("Thread: " + id + " procedued data into queue: " + data + " ...");
                if (!queue.offer(data, 2, TimeUnit.SECONDS)) {
                    System.out.println("failed to put data into queue: " + data);
                }
            }
        } catch (InterruptedException e) {
            e.printStackTrace();
            Thread.currentThread().interrupt();
        } finally {
            System.out.println("Thread: " + id + " quit from producer thread");
        }
    }
}

2.定义消费者


class Consumer implements Runnable {

    /**
     * 用util.concurrent.BlockingQueue沟通生产者和消费者的桥梁
     */
    private BlockingQueue<String> queue;
    private String id;


    private
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值