多线程与高并发(12)——BlockingQueue

BlockingQueue主要用来控制线程通信,当生产者试图向阻塞队列中放入元素而BlockingQueue已满,则该线程被阻塞。当消费者试图向阻塞队列中取出元素而BlockingQueue已满,则该线程被阻塞。(这里元素添加、删除使用put(),take()方法才会阻塞,使用add()/offer(),remove()/pull()则有其它表现)

BlockingQueue的一个基于数组的实现类就是ArrayBlockingQueue,请看下列示例代码。

class Producer extends Thread {
    private BlockingQueue<String> bq;

    public Producer(BlockingQueue<String> bq) {
        this.bq = bq;
    }

    @Override
    public void run() {
        String[] str = new String[] { "hello,", "world!", "I'm wz" };
        for (int i = 0; i < 99999; i++) {
            System.out.println(getName() + "start produce item!");
            try {
                Thread.sleep(200);
                bq.put(str[i % 3]);
            } catch (Exception e) {
                e.printStackTrace();
            }
            System.out.println(getName() + "finish produce item!" + bq);
        }

    }
}

class Consumer extends Thread {
    private BlockingQueue<String> bq;

    public Consumer(BlockingQueue<String> bq) {
        this.bq = bq;
    }

    @Override
    public void run() {
        while (true) {
            System.out.println(getName() + "start Consume item!");
            try {
                Thread.sleep(200);
                bq.take();
            } catch (Exception e) {
                e.printStackTrace();
            }
            System.out.println(getName() + "finish Consume item!" + bq);
        }
    }
}

public class BlockingQueueTest {
    public static void main(String[] args) {
        BlockingQueue<String> bq = new ArrayBlockingQueue<>(1);
        new Producer(bq).start();
        new Producer(bq).start();
        new Producer(bq).start();
        new Consumer(bq).start();
    }
}
java全栈日日学 文章被收录于专栏

java全栈每日必学,不要高估自己一年能做的事,不要低估自己十年能做的事

全部评论

相关推荐

07-22 11:35
门头沟学院 Java
谁知道这是为什么吗,有没有懂的佬给讲讲
理智的小饼干又熬夜了:鹅打电话问我参不参加后台提前批,说是有的但还没放官网
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务