java多线程(五)ArrayBlockingQueue阻塞队列

本文通过实例代码详细介绍了Java中ArrayBlockingQueue阻塞队列的使用,包括添加、移除和检测队首元素的方法,如add、offer、put、poll、take及peek等,并展示了异常处理和超时操作。通过示例展示了当队列满时的异常情况以及阻塞和超时等待的行为。
摘要由CSDN通过智能技术生成

java多线程ArrayBlockingQueue阻塞队列

方法跑出异常有返回值,不抛异常阻塞 等等超时等等
添加addofferputoffe(,)
移除removepolltakepoll(,)
检测队首元素elementpeek--
import java.util.concurrent.ArrayBlockingQueue;
import java.util.concurrent.TimeUnit;

public class ArrayBlockingQueueDemo {

	public static void main(String[] args) {

		System.out.println("第一组:===================");
		ArrayBlockingQueue<String> abq = new ArrayBlockingQueue<>(3);

		try {
			abq.add("a");
			abq.add("b");
			abq.add("c");
			abq.add("d");// 报异常
		} catch (Exception e) {
			e.printStackTrace();
		}

		String fe = abq.element();// 检测队首元素
		System.out.println("队首元素:" + fe);
		try {
			System.out.println(abq.remove());
			System.out.println(abq.remove());
			System.out.println(abq.remove());
			System.out.println(abq.remove());// 报异常
		} catch (Exception e) {
			e.printStackTrace();
		}
		System.out.println("第二组:===================");

		ArrayBlockingQueue<String> abq2 = new ArrayBlockingQueue<>(3);
		abq2.offer("aa");
		abq2.offer("bb");
		abq2.offer("cc");
		abq2.offer("dd");// 返回false

		String peek = abq2.peek();// 检测队首元素
		System.out.println("队首元素:" + peek);
		System.out.println(abq2.poll());
		System.out.println(abq2.poll());
		System.out.println(abq2.poll());
		System.out.println(abq2.poll());// 返回null

//		System.out.println("第三组:===================");
//
//		try {
//			ArrayBlockingQueue<String> abq3 = new ArrayBlockingQueue<>(3);
//			abq3.put("aaa");
//			abq3.put("bbb");
//			abq3.put("ccc");
//			abq3.put("ddd");// 一直阻塞,死等
//
//			System.out.println(abq3.take());
//			System.out.println(abq3.take());
//			System.out.println(abq3.take());
//			System.out.println(abq3.take());// 一直阻塞,死等
//		} catch (Exception e) {
//			e.printStackTrace();
//		}

		System.out.println("第四组:===================");
		try {
			ArrayBlockingQueue<String> abq4 = new ArrayBlockingQueue<>(3);
			abq4.offer("aaaa", 2, TimeUnit.SECONDS);
			abq4.offer("bbbb", 2, TimeUnit.SECONDS);
			abq4.offer("cccc", 2, TimeUnit.SECONDS);
			abq4.offer("dddd", 2, TimeUnit.SECONDS);

			System.out.println(abq4.poll(2, TimeUnit.SECONDS));
			System.out.println(abq4.poll(2, TimeUnit.SECONDS));
			System.out.println(abq4.poll(2, TimeUnit.SECONDS));
			System.out.println(abq4.poll(2, TimeUnit.SECONDS));
		} catch (Exception e) {
			e.printStackTrace();
		}

	}
}

运行结果

第一组:===================
java.lang.IllegalStateException: Queue full
	at java.util.AbstractQueue.add(AbstractQueue.java:98)
	at java.util.concurrent.ArrayBlockingQueue.add(ArrayBlockingQueue.java:312)
	at com.asia.tip.tcpchat.ArrayBlockingQueueDemo.main(ArrayBlockingQueueDemo.java:17)
队首元素:a
a
b
c
java.util.NoSuchElementException
	at java.util.AbstractQueue.remove(AbstractQueue.java:117)
	at com.asia.tip.tcpchat.ArrayBlockingQueueDemo.main(ArrayBlockingQueueDemo.java:28)
第二组:===================
队首元素:aa
aa
bb
cc
null
第四组:===================
aaaa
bbbb
cccc
null

特别鸣谢:狂神说Java老师的无私奉献

.
.
.
上一篇 java多线程(四)ReadWriteLock读写锁
下一篇 java多线程(六) SynchronousQueue同步队列

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

老李笔记

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值