blockingqueue学习笔记

一。接口blockingqueue

      1>BlockingQueue是一种特殊的queue,特殊性如下:
      若blockingQueue是空的,从该队列中取东西的操作将会被阻断进入等待状态,知道blockingqueue进了新货才会被唤醒。
      若blockingQueue是满的,向该队列中村东西的操作也会被阻断进入等待状态,直到blockingqueue有了空间才会被唤醒
     2>BlockingQueue主要有以下方法

     添加类方法:
    add(Object)方法:如果没满返回true,如果满了抛出illegalStateException
     offer(Object)方法:如果没满返回true,如果满了返回false
     put(Object)方法:如果没满返回true,如果满了阻塞直到有新空间
    拿取类方法:
    poll(time)方法:如果为空阻塞,如果一直为空time时间后返回null
    take()方法:如果为空一直阻塞到不为空

二。BlockingDeque

      deque一般是双端队列,会比queue多addFirst、addLast、等方法,具体方法参考queue。

三。BlockingQueue和BLockingDeque的几种实现

    1>ArrayBlockingQueue

          是线程安全的,构造器必须带长度,可以规定访问策略是否为FIFO(先入先出) 默认就是FIFO的,fair参数如果是false的话,先入不能保证,所以先出也没用了,原因是在竞争锁时,不能保证顺序。

    2>LinkedBlockingQueue

           线程安全的,构造器可以不定义大小,也可以定义。若不带大小,最大为Integer.MAX_VALUE决定

    1>、2>相比,2的数据吞吐量要大,但在线程数量很大是,其性能的可预见性要低于1

    3>PriorityBlockingQueue。

            它最大的特点是

            可以自己定义一个比较器,个性化为队列的顺序排序。用法很简单。

    4>SynchronousQueue

            这个queue比较特殊,对其操作必须是放和取交替完成的。用到再研究

 

四。用BlockingQueue来实现Producer和Consumer的例子,代码如下:

 

public class BlockingQueueTest {
    public static class Basket {
        BlockingQueue<String> basket = new ArrayBlockingQueue<String>(3);
        public void produce() throws InterruptedException {
            basket.put("An apple");
        }
        public int getSize(){
            return basket.size();
        }
        public String consume() throws InterruptedException {
            return basket.take();
        }
    }

    public static void testBasket() {
        final Basket basket = new Basket();
        class Consumer implements Runnable {

            @Override
            public void run() {
                try {
                    while (true) {
                        System.out.println("消费苹果"+(basket.getSize()+1)+"中");
                        basket.consume();
                        System.out.println("消费"+basket.getSize()+"苹果");
                        Thread.sleep(1000);
                    }
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
            }
        }
        class Producer implements Runnable {


            @Override
            public void run() {
                try {
                    while (true) {
                        System.out.println("生产"+(basket.getSize()+1)+"苹果中");
                        basket.produce();
                        System.out.println("生产"+basket.getSize()+"苹果");
                        Thread.sleep(300);
                    }
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
            }
        }
        ExecutorService service=Executors.newCachedThreadPool();
        Producer producer=new Producer();
        Consumer consumer=new Consumer();
        service.submit(producer);
        service.submit(consumer);
        try {
            Thread.sleep(5000);
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
        service.shutdownNow();
    }
    public static void main(String[] args) {
        testBasket();
    }
}

 

 

 

 

 

 

 

 

 

 

 

转载于:https://my.oschina.net/u/2323537/blog/615956

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值