LinkedList的用法

2019-02-25  本文已影响0人  刘昱涵

如何构造

// 默认构造函数
LinkedList()
// 创建一个LinkedList,保护Collection中的全部元素。
LinkedList(Collection<? extends E> collection)

例如

import java.util.Arrays;
import java.util.LinkedList;

public class Test {
    public static void main(String[] args){
        LinkedList<String> textOne = new LinkedList<>();
        String[] array = {"a","b","c","d"};
        LinkedList<String> textTwo = new LinkedList<>(Arrays.asList(array));
        System.out.println(textOne);
        System.out.println(textTwo);
    }
}

结果为

[]
[a, b, c, d]

常用方法

1、获取其首位或末位元素
List.getFirst()
List.getLast()
以上面创建的例子来说

System.out.println("链表的第一个元素是 : " + textTwo.getFirst());  
System.out.println("链表最后一个元素是 : " + textTwo.getLast());  

结果为

链表的第一个元素是 : a
链表最后一个元素是 : d

2、删除第一个或最后一个元素
list.removeFirst();
list.removeLast();

System.out.println(textTwo.removeFirst());  
System.out.println(textTwo.removeLast());  
System.out.println(textTwo);

结果是

a
d
[b, c]

3、查找元素位置
List.indexOf()

System.out.println(textTwo.indexOf("b"));  

结果为

1

4、根据范围删除元素
list.subList(1,2).clear()

textTwo.subList(1,2).clear();
System.out.println(textTwo);

结果为

[a, c, d]

5、添加元素
尾部添加
list.add()

textTwo.add("e");
System.out.println(textTwo);

结果

[a, b, c, d, e]

首部添加

textTwo.addFirst("e");
System.out.println(textTwo);

结果

[e, a, b, c, d]

指定位置添加

textTwo.add(2,"e");
System.out.println(textTwo);

结果

[a, b, e, c, d]

6、获取指定位置的元素
list.get()
首位list.getFirst()
末位list.getLast()

System.out.println(textTwo.getFirst());
System.out.println(textTwo.getLast());
System.out.println(textTwo.get(2));

结果

a
d
c

7、查询链表列表的长度(元素个数)
list.size()

System.out.println(textTwo.size());

结果

4

遍历方法

1、一般的for循环(随机访问)

int size = textTwo.size();
for (int i=0; i<size; i++) {
    System.out.println(textTwo.get(i));
}

结果

a
b
c
d

2、for--each循环

for (String string:textTwo) {
            System.out.println(textTwo);
        }

结果

[a, b, c, d]
[a, b, c, d]
[a, b, c, d]
[a, b, c, d]

3、迭代器iterator

for(Iterator iter = list.iterator(); iter.hasNext();)
    iter.next();

4、用pollLast()来遍历LinkedList

while(textTwo.pollLast() != null)
System.out.println("a");

结果

a
a
a
a

上一篇下一篇

猜你喜欢

热点阅读