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