Java Queue add/offer ,element/peek , remove/poll 区别说明

在 Java Queue 上 add/offer ,element/peek , remove/poll 中三个方法均为重复方法 , 在选择使用时不免有所疑惑 , 这是简单说明下 :

1. add() 和 offer() 的区别

add() 和 offer() 都是向队列中添加一个元素 . 一些队列有大小限制,因此如果想在已满的队列加入一个新队列, 调用 add() 方法就会抛出一个 unchecked 异常, 而调用 offer() 方法返回 flase . 因此就可以在程序中进行有效的判断 .

2. poll() 和 remove() 的区别

poll() 和 remove() 方法都是从队列中删除第一个元素. 如果队列元素为空 ,调用 remove() 的行为与 Collection 接口的版本相似会抛出异常 . 但是新的 poll() 方法会在用空集合调用时只会返回 null . 因此新的方法更适合容易出现异常条件的情况.

3. element() 和 peek() 的区别

element() 和 peek()用于在队列的头部查询元素. 与 remove() 方法类似 , 在队列为空时 , element () 抛出一个异常 , 而 peek()返回 null .

下面 Java 中 Queue 的一些常用方法 :

其中put()take()BlockingQueue专属方法.

操作方法作用异常情况
add 添加一个元素 如果队列已满 , 则抛出一个 IIIegalSlabExcepiton 异常
offer 添加一个元素并返回true 如果队列已满, 则返回 false
put 添加一个元素 如果队列已满, 则阻塞
remove 移除并返回队列头部元素 如果队列为空, 则抛出一个 NoSuchElementException异常
poll 移除并返回队列头部元素 如果队列为空, 则返回null
take 移除并返回队列头部元素  
element 返回队列头部元素 如果队列为空 , 则抛出一个NoSuchElementException 异常
peek 返回队列头部元素 如果队列为空, 则返回 null
原文地址:https://www.cnblogs.com/quyc/p/14418761.html