java并发队列之ArrayBlockingQueue、LinkedBlockingQueue

ArrayBlockingQueue和LinkedBlockingQueue用法上没有什么区别,所以就放在一起把。

特点:阻塞队列,ArrayBlockingQueue定义时需要给定长度(有界队列),LinkedBlockingQueue定义时可给可不给(无界队列)。put函数在超出队列长度就会阻塞,take函数在队列中无数据会阻塞。offer函数和poll函数不会发生阻塞,有返回参数。add函数在超出队列长度时会报错,remove函数可以移除指定数据。

区别:ArrayBlockingQueue在添加和取出共用一把锁,而LinkedBlockingQueue是分开的两把锁。另一个区别看就是一个底层实现是数组一个是单向链表,数组和链表的区别就是数组适合读取,插入和删除都会影响数组中其余元素,链表正好相反,适合插入删除只会影响关联的的一个元素,不适合读取,读取会重头开始读取。

应用场景:用到队列的场景基本都是这个。

代码案例:

package com.example.web.web;

import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

import java.util.concurrent.ArrayBlockingQueue;
import java.util.concurrent.TimeUnit;

@RestController
public class HomeController {

    @RequestMapping("/index")
    public String index() throws Exception {
        ArrayBlockingQueue<String> queue = new ArrayBlockingQueue<>(2);
        //生产者
        new Thread(() ->
        {
            try {
                TimeUnit.MILLISECONDS.sleep(5000);
                System.out.println("生产者begin");
                queue.put("测试数据");
                //queue.offer("测试数据", 5, TimeUnit.SECONDS);
                System.out.println("生产者end");
            } catch (Exception ex) {
            }
        }).start();

        //消费者
        new Thread(() ->
        {
            try {
                System.out.println("消费者begin");
                //String aa = queue.take();
                String aa = queue.poll(2, TimeUnit.SECONDS);
                System.out.println("消费者end" + aa);
            } catch (Exception ex) {
            }
        }).start();

        //主线程也等待下
        TimeUnit.SECONDS.sleep(10);
        return "网站已得到响应";
    }
}

参考链接:

http://ifeve.com/java-blocking-queue/

https://www.cnblogs.com/liqiu/p/3630281.html

http://www.importnew.com/24055.html

转载于:https://my.oschina.net/uwith/blog/3056692

猜你喜欢

转载自blog.csdn.net/weixin_34313182/article/details/91710190