😀如果对你有帮助的话😊
🌺为博主点个赞吧 👍
👍点赞是对博主最大的鼓励😋
💓爱心发射~💓
1、add 和 offer的区别
queue
的增加元素方法add
和offer
的区别在于
add
方法在队列满的情况下将选择抛异常
的方法来表示队列已经满了- 而
offer
方法通过返回false
表示队列已经满了
在有限队列的情况,使用offer
方法优于add
方法
2、remove 和 poll的区别
remove
方法和poll
方法都是删除队列的头元素,
emove
方法在队列为空的情况下将抛异常
- 而
poll
方法将返回null
3、element 和 peek的区别
element
和peek
方法都是返回队列的头元素,但是不删除头元素,区别在
element
方法在队列为空的情况下,将抛异常
- 而
peek
方法将返回null
总结
方法名 | 作用 | 是否有异常 |
---|---|---|
add | 增加一个元索 | 队列已满,则抛出一个IIIegaISlabEepeplian异常 |
remove | 移除并返回队列头部的元素 | 队列为空,则抛出一个NoSuchElementException异常 |
element | 返回队列头部的元素 | 队列为空,则抛出一个NoSuchElementException异常 |
offer | 添加一个元素并返回true | 队列已满,则返回false |
poll | 移除并返问队列头部的元素 | 队列为空,则返回null |
peek | 返回队列头部的元素 | 队列为空,则返回null |
put | 添加一个元素 | 如果队列满,则阻塞 |
take | 移除并返回队列头部的元素 | 队列为空,则阻塞 |
一般都用offer
添加、poll
移除、peek
源码
public interface Queue<E> extends Collection<E> {
/*
* add方法,在不违背队列的容量限制的情况,往队列中添加一个元素, 如果添加成功则返回true, 如果因为容量
* 限制添加失败了,则抛出IllegalStateException异常
*
* 在有容量限制的队列中,最好使用offer方法
* 另外,add方法相对与offer方法而言,有一个专门抛出的异常IllegalStateException,代表由于容量限制,
* 导致不能添加元素的异常,接口中可能看不出,等看具体实现就明白了
*/
boolean add(E e);
/*
*
* offer方法在不违背容量限制的情况,往队列中添加一个元素,如果添加元素成功,返回true,
* 如果因为空间限制,无法添加元素则,返回false;
*
* 在有容量限制的队列中,这个offer方法优于add方法,结合上文中add的注释,可知,
* 在容量限制的队列中, add方法通过抛异常的方式表示容量已满,offer方法通过返回
* false的方式表示容量已满,抛异常处理更加耗时,offer直接返回false的方式更好
*/**
boolean offer(E e);
/*
* 删除队列头的元素,这个方法和poll方法的不同之处在于,这个方法在队列为
* 空的时候选择抛异常
*/
E remove();
// 删除队列头的元素,如果队列为空,返回null
E poll();
// 返回队列头元素,这个方法和peek方法的区别在于,入股队列为空,将抛异常
E element();
// 返回队列头元素,如果队列为空,将返回空
E peek();
}