Posts /

Java Queue中存取方法的区别

14 Jul 2020

Java Queue中存取方法的区别


offer、add

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
    }
    
}

poll、remove

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

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

    }
    
}