add()和offer()都是向队列中添加一个元素,一些队列有大小限制,因此如果想在一个满的队列中加入一个新项,调用 add() 方法就会抛出一个 unchecked 异常,而调用 offer() 方法会返回 false。因此就可以在程序中进行有效的判断!
offer()在队列满时返回false
add()在队列满时抛出异常
/**
* @description:
* @modifyContent:
* @author: Maple Chan
* @date: 2020-07-14 20:22:37
* @version: 0.0.1
*/
public class JavaQueue {
public static void main(String[] args) {
Queue<Integer> queue = new LinkedBlockingQueue<>(3);
queue.add(1);
queue.add(2);
queue.add(3);
// queue.add(3);
// Exception in thread "main" java.lang.IllegalStateException: Queue full
// at java.util.AbstractQueue.add(AbstractQueue.java:98)
// at Java_test.JavaQueue.main(JavaQueue.java:22)
boolean isSucceed = queue.offer(3);
System.out.println(isSucceed);
// false
}
}
remove()和poll()方法都是从队列中删除第一个元素,如果队列为空,调用remove() 的行为与 Collection 接口的版本相似会抛出异常。但是 poll() 方法在用空集合调用时只是返回 null。因此新的方法更适合容易出现异常条件的情况。
poll()在空队列返回null
add()在空队列抛出异常
/**
* @description:
* @modifyContent:
* @author: Maple Chan
* @date: 2020-07-14 20:22:37
* @version: 0.0.1
*/
public class JavaQueue {
public static void main(String[] args) {
Queue<Integer> queue2 = new LinkedBlockingQueue<>(3);
// Integer integer = queue2.remove();
// Exception in thread "main" java.util.NoSuchElementException
// at java.util.AbstractQueue.remove(AbstractQueue.java:117)
// at Java_test.JavaQueue.main(JavaQueue.java:31)
Integer integer = qeue2.poll();
System.out.println(integer);
//null
}
}
element() 和 peek() 用于在队列的头部查询元素。与 remove() 方法类似,在队列为空时, element() 抛出一个异常,而 peek() 返回 null。
peek()在空队列返回null
element()在空队列抛出异常
/**
* @description:
* @modifyContent:
* @author: Maple Chan
* @date: 2020-07-14 20:22:37
* @version: 0.0.1
*/
public class JavaQueue {
public static void main(String[] args) {
Queue<Integer> queue3 = new LinkedBlockingQueue<>(3);
// Integer integer2 = queue3.element();
// Exception in thread "main" java.util.NoSuchElementException
// at java.util.AbstractQueue.element(AbstractQueue.java:136)
// at Java_test.JavaQueue.main(JavaQueue.java:43)
Integer integer2 = queue3.peek();
System.out.println(integer2);
// null
}
}