顾名思义,阻塞队列应该满足队列的基本特征,即先进先出,并且其还有一些其他特性,当队列为空时,从队列中获取元素将被阻塞,而当队列元素已满时,向队列添加元素将被阻塞。
例子:
添加方法
add
BlockingQueue<String> blockingQueue = new ArrayBlockingQueue<>(3);
System.out.println(blockingQueue.add("a"));
blockingQueue.add("b");
blockingQueue.add("c");
blockingQueue.add("d");
在这个例子中,我们设置了阻塞队add列的容量为3,当添加的数量大于3时,便会抛出java.lang.IllegalStateException: Queue full该异常,如果添加成功,则会返回一个boolean类型的值(true)
offer(特殊值)
BlockingQueue<String> blockingQueue = new ArrayBlockingQueue<>(3);
System.out.println(blockingQueue.offer("a"));
blockingQueue.offer("b");
blockingQueue.offer("c");
System.out.println(blockingQueue.offer("d"));
同样也是向阻塞队列中添加元素,但是此方法当超过该阻塞队列容量时,再添加元素,并不会抛出异常,而是返回一个boolean的值(false)
同时offer插入还有另一种方法,在等待指定之间后,还不能插入成功,则返回false,同时该方法会抛出异常:
BlockingQueue<String> blockingQueue = new ArrayBlockingQueue<>(3);
System.out.println(blockingQueue.offer("a"));
blockingQueue.offer("b");
blockingQueue.offer("c");
try {
System.out.println(blockingQueue.offer("d",3L, TimeUnit.SECONDS));
} catch (InterruptedException e) {
e.printStackTrace();
}
put(阻塞)
BlockingQueue<String> blockingQueue = new ArrayBlockingQueue<>(3);
try {
blockingQueue.put("a");
blockingQueue.put("b");
blockingQueue.put("c");
blockingQueue.put("e");
} catch (InterruptedException e) {
e.printStackTrace();
}
该方法也是向队列中添加元素,但与前两者不同,该方法没有返回值,同时会抛出异常(InterruptedException),当在超过阻塞队列容量后再添加元素,便会阻塞,直至阻塞队列中又有容量的时候便会插入元素(即在队列满后执行take操作,后面会介绍)
讲完添加,自然就到了移除:
移除方法
remove
BlockingQueue<String> blockingQueue = new ArrayBlockingQueue<>(3);
blockingQueue.offer("a");
blockingQueue.offer("b");
blockingQueue.offer("c");
System.out.println(blockingQueue.remove());
System.out.println(blockingQueue.remove());
System.out.println(blockingQueue.remove());
System.out.println(blockingQueue.remove());
该方法与add对应,当阻塞队列中元素为空时,此时再移除元素,便会抛出异常(java.util.NoSuchElementException)
pull
BlockingQueue<String> blockingQueue = new ArrayBlockingQueue<>(3);
blockingQueue.offer("a");
blockingQueue.offer("b");
blockingQueue.offer("c");
System.out.println(blockingQueue.poll());
System.out.println(blockingQueue.poll());
System.out.println(blockingQueue.poll());
System.out.println(blockingQueue.poll());
该方法与offer对应,当阻塞队列元素为空时,再移除元素,并不会抛出异常,而是返回null
同时其也有与offer对应的另一种方法,即等待一定时间,如果时间到了,阻塞队列依然没有元素,则返回null,这里便不演示了
take
BlockingQueue<String> blockingQueue = new ArrayBlockingQueue<>(3);
blockingQueue.offer("a");
blockingQueue.offer("b");
blockingQueue.offer("c");
System.out.println(blockingQueue.take());
System.out.println(blockingQueue.take());
System.out.println(blockingQueue.take());
System.out.println(blockingQueue.take());
该方法与put对应,当阻塞队列元素为空时,再向其去取元素,则会被阻塞,直到阻塞队列重新有元素,同时,该方法也会抛出InterruptedException。
其他方法
element
该方法是检查队首元素,不会取出元素,当队列为空时,会报出NoSuchElementException
peek
该方法是检查队首元素,不会取出元素,当队列为空时,会返回null