Java BlockingQueue阻塞队列的四组API

BlockingQueueFIFO(先进先出)型队列,他很好的解决了多线程中,如何高效安全“传输”数据的问题。本文会介绍BlockingQueue常用的四组api以及他们之间的不同之处。

方式返回布尔,抛出异常返回布尔,不抛出异常阻塞,一直等待阻塞,超时等待
添加add(e)offer(e)put(e)offer(e, timeout, unit)
移出remove( )poll( )take( )poll(timeout, unit)
返回队首元素element( )peek( )

返回布尔,抛出异常:

// 容量大小为3
ArrayBlockingQueue<String> blockingQueue = new ArrayBlockingQueue<String>(3);
// add() 向队列添加元素,返回布尔值
System.out.println(blockingQueue.add("a"));
System.out.println(blockingQueue.add("b"));
System.out.println(blockingQueue.add("c"));
// 超过容量,抛异常 IllegalStateException: Queue full
//System.out.println(blockingQueue.add("d"));
// 返回队首元素
System.out.println("top = " + blockingQueue.element());

System.out.println("-------------");
System.out.println(blockingQueue.remove());
System.out.println(blockingQueue.remove());
System.out.println(blockingQueue.remove());
// 无元素,抛异常 NoSuchElementException
//System.out.println(blockingQueue.remove());
// 返回队首元素,抛异常 NoSuchElementException
//System.out.println("top = " + blockingQueue.element());

运行结果:
在这里插入图片描述
add(e)异常:
在这里插入图片描述

remove( )异常:
在这里插入图片描述
element( )异常
在这里插入图片描述


返回布尔,不抛异常:

// 容量大小为3
ArrayBlockingQueue<String> blockingQueue = new ArrayBlockingQueue<String>(3);
// offer() 向队列添加元素,返回布尔值
System.out.println(blockingQueue.offer("a"));
System.out.println(blockingQueue.offer("b"));
System.out.println(blockingQueue.offer("c"));
// 不抛异常,返回false
System.out.println(blockingQueue.offer("d"));
// 返回队首元素
System.out.println("top = " + blockingQueue.peek());

System.out.println("-------------");
System.out.println(blockingQueue.poll());
System.out.println(blockingQueue.poll());
System.out.println(blockingQueue.poll());
// 无元素,不抛异常 返回null
System.out.println(blockingQueue.poll());
// 返回队首元素,不抛异常
System.out.println("top = " + blockingQueue.peek());

运行结果:
在这里插入图片描述


阻塞,一直等待:

// 容量大小为3
ArrayBlockingQueue<String> blockingQueue = new ArrayBlockingQueue<String>(3);
blockingQueue.put("a");
blockingQueue.put("b");
blockingQueue.put("c");
// 队列没有位置了,一直阻塞
//blockingQueue.put("d");

System.out.println(blockingQueue.take());
System.out.println(blockingQueue.take());
System.out.println(blockingQueue.take());
// 队列没有元素了,一直阻塞
//System.out.println(blockingQueue.take());

运行结果:
在这里插入图片描述
当队列没有剩余位置可以插入元素,或没有元素可以取出时,会一直阻塞。


阻塞,超时等待:

// 容量大小为3
ArrayBlockingQueue<String> blockingQueue = new ArrayBlockingQueue<String>(3);
// offer() 向队列添加元素,返回布尔值
System.out.println(blockingQueue.offer("a"));
System.out.println(blockingQueue.offer("b"));
System.out.println(blockingQueue.offer("c"));
// 等待2s,超时取消阻塞
System.out.println(blockingQueue.offer("d", 2, TimeUnit.SECONDS));

System.out.println("-------------");
System.out.println(blockingQueue.poll());
System.out.println(blockingQueue.poll());
System.out.println(blockingQueue.poll());
// 等待2s,超时取消阻塞
System.out.println(blockingQueue.poll(2, TimeUnit.SECONDS));

运行结果:
在这里插入图片描述
带参数的offer(e, timeout, unit):
在这里插入图片描述
带参数的poll(timeout, unit):
在这里插入图片描述

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值