parent
a87b064460
commit
cfa9b88f1a
@ -0,0 +1,34 @@ |
||||
--- |
||||
LinkedList |
||||
--- |
||||
|
||||
#### 整体结构 |
||||
|
||||
```java |
||||
public class LinkedList<E> |
||||
extends AbstractSequentialList<E> |
||||
implements List<E>, Deque<E>, Cloneable, java.io.Serializable |
||||
{} |
||||
``` |
||||
|
||||
既然实现了 Deque 接口,就说明 LinkedList 其实是一个双向链表。 |
||||
|
||||
#### 方法对比 |
||||
|
||||
| 方法含义 | 返回异常 | 返回特殊值 | 底层实现 | |
||||
| -------- | --------- | ---------- | --------------------------------------------- | |
||||
| 新增 | add(e) | offer(e) | 底层实现相同 | |
||||
| 删除 | remove(e) | poll(e) | 链表为空时,remove 会抛出异常,poll 返回 null | |
||||
| 查找 | element() | peek() | 链表为空,element 会抛出异常,peek 返回 null | |
||||
|
||||
Queue 接口注释建议 add 方法操作失败时抛出异常,但 LinkedList 实现的 add 方法一直返回 true。 |
||||
|
||||
#### 迭代器 |
||||
|
||||
因为 LinkedList 要实现双向的迭代访问,所以我们使用 Iterator 接口肯定不行了,因为 Iterator 只支持从头到尾的访问。Java 新增了一个迭代接口,叫做 ListIterator,这个接口提供了向前和向后的迭代方法,如下所示: |
||||
|
||||
| 迭代顺序 | 方法 | |
||||
| ---------------- | ------------------------------------ | |
||||
| 从尾到头迭代方法 | hasPrevious、previous、previousIndex | |
||||
| 从头到尾迭代方法 | hasNext、next、nextIndex | |
||||
|
Loading…
Reference in new issue