目录
一、简介
链表(Linked list)是一种常见的基础数据结构,是一种线性表,但是并不会按线性的顺序存储数据,而是在每一个节点里存到下一个节点的地址。
链表可分为单向链表和双向链表。
Java LinkedList(链表) 类似于 ArrayList,是一种常用的数据容器。
与 ArrayList 相比,LinkedList 的增加和删除的操作效率更高,而查找和修改的操作效率较低。
以下情况使用 ArrayList :
- 频繁访问列表中的某一个元素。
- 只需要在列表末尾进行添加和删除元素操作。
以下情况使用 LinkedList :
- 你需要通过循环迭代来访问列表中的某些元素。
- 需要频繁的在列表开头、中间、末尾等位置进行添加和删除元素操作。
二、添加
添加元素可通过add、addFirst、addLast等方法进行添加。
package com.wxl.springbootpro01;
import java.util.LinkedList;
public class Test {
@org.junit.jupiter.api.Test
public void linkedListTest(){
LinkedList<Object> linkedList=new LinkedList<>();
linkedList.add(123);
linkedList.add("Jack");
linkedList.addFirst("I am Jack");
linkedList.addLast("finished");
System.out.println(linkedList);
}
}
通过迭代器也能实现在指定位置添加元素
package com.wxl.springbootpro01;
import java.util.LinkedList;
import java.util.ListIterator;
public class Test {
@org.junit.jupiter.api.Test
public void linkedListTest(){
LinkedList<Object> linkedList=new LinkedList<>();
linkedList.add(123);
linkedList.add("Jack");
linkedList.addFirst("I am Jack");
linkedList.addLast("finished");
ListIterator<Object> it=linkedList.listIterator();
while(it.hasNext()){
Object item=it.next();
if(item.equals("Jack")){
it.add("AAA");
}
}
System.out.println(linkedList);
}
}
三、删除
通过remove(position)、removeFirst()、removeLast()等方法来删除。
package com.wxl.springbootpro01;
import java.util.LinkedList;
public class Test {
@org.junit.jupiter.api.Test
public void linkedListTest(){
LinkedList<Object> linkedList=new LinkedList<>();
linkedList.add(123);
linkedList.add("Jack");
linkedList.addFirst("I am Jack");
linkedList.addLast("finished");
linkedList.remove(2);
linkedList.removeFirst();
linkedList.removeLast();
System.out.println(linkedList);
}
}
四、遍历
获取单个元素可以使用get(positon)、getLast()、getFirst()等方法。
package com.wxl.springbootpro01;
import java.util.LinkedList;
public class Test {
@org.junit.jupiter.api.Test
public void linkedListTest(){
LinkedList<Object> linkedList=new LinkedList<>();
linkedList.add(123);
linkedList.add("Jack");
linkedList.addFirst("I am Jack");
linkedList.addLast("finished");
for (Object o:linkedList){
System.out.println(o);
}
System.out.println(linkedList.get(2));
System.out.println(linkedList.getFirst());
System.out.println(linkedList.getLast());
}
}
五、修改
可以使用迭代器来对指定位置进行修改
package com.wxl.springbootpro01;
import java.util.LinkedList;
import java.util.ListIterator;
public class Test {
@org.junit.jupiter.api.Test
public void linkedListTest(){
LinkedList<Object> linkedList=new LinkedList<>();
linkedList.add(123);
linkedList.add("Jack");
linkedList.addFirst("I am Jack");
linkedList.addLast("finished");
ListIterator<Object> it=linkedList.listIterator();
while(it.hasNext()){
Object item=it.next();
if(item.equals("Jack")){
it.set("BBB");
break;
}
}
System.out.println(linkedList);
}
}
六、常用方法
方法 | 描述 |
---|---|
public boolean add(E e) | 链表末尾添加元素,返回是否成功,成功为 true,失败为 false。 |
public void add(int index, E element) | 向指定位置插入元素。 |
public boolean addAll(Collection c) | 将一个集合的所有元素添加到链表后面,返回是否成功,成功为 true,失败为 false。 |
public boolean addAll(int index, Collection c) | 将一个集合的所有元素添加到链表的指定位置后面,返回是否成功,成功为 true,失败为 false。 |
public void addFirst(E e) | 元素添加到头部。 |
public void addLast(E e) | 元素添加到尾部。 |
public boolean offer(E e) | 向链表末尾添加元素,返回是否成功,成功为 true,失败为 false。 |
public boolean offerFirst(E e) | 头部插入元素,返回是否成功,成功为 true,失败为 false。 |
public boolean offerLast(E e) | 尾部插入元素,返回是否成功,成功为 true,失败为 false。 |
public void clear() | 清空链表。 |
public E removeFirst() | 删除并返回第一个元素。 |
public E removeLast() | 删除并返回最后一个元素。 |
public boolean remove(Object o) | 删除某一元素,返回是否成功,成功为 true,失败为 false。 |
public E remove(int index) | 删除指定位置的元素。 |
public E poll() | 删除并返回第一个元素。 |
public E remove() | 删除并返回第一个元素。 |
public boolean contains(Object o) | 判断是否含有某一元素。 |
public E get(int index) | 返回指定位置的元素。 |
public E getFirst() | 返回第一个元素。 |
public E getLast() | 返回最后一个元素。 |
public int indexOf(Object o) | 查找指定元素从前往后第一次出现的索引。 |
public int lastIndexOf(Object o) | 查找指定元素最后一次出现的索引。 |
public E peek() | 返回第一个元素。 |
public E element() | 返回第一个元素。 |
public E peekFirst() | 返回头部元素。 |
public E peekLast() | 返回尾部元素。 |
public E set(int index, E element) | 设置指定位置的元素。 |
public Object clone() | 克隆该列表。 |
public Iterator descendingIterator() | 返回倒序迭代器。 |
public int size() | 返回链表元素个数。 |
public ListIterator listIterator(int index) | 返回从指定位置开始到末尾的迭代器。 |
public Object[] toArray() | 返回一个由链表元素组成的数组。 |
public T[] toArray(T[] a) | 返回一个由链表元素转换类型而成的数组。 |
更多方法:LinkedList