LinkedList的用法

如何构造

// 默认构造函数
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

©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • LinkedList的本质是双向链表。它也可以被当作堆栈、队列或双端队列进行操作。它采用的是链表式储存,所以比较适...
    加一片柠檬233阅读 853评论 0 0
  • 一、基础知识:1、JVM、JRE和JDK的区别:JVM(Java Virtual Machine):java虚拟机...
    杀小贼阅读 2,538评论 0 4
  • 专业考题类型管理运行工作负责人一般作业考题内容选项A选项B选项C选项D选项E选项F正确答案 变电单选GYSZ本规程...
    小白兔去钓鱼阅读 10,357评论 0 13
  • 1.ArrayList是实现了基于动态数组的数据结构,LinkedList基于链表的数据结构。2.对于随机访问ge...
    AiPuff阅读 1,104评论 0 6
  • 四、集合框架 1:String类:字符串(重点) (1)多个字符组成的一个序列,叫字符串。生活中很多数据的描述都采...
    佘大将军阅读 853评论 0 2

友情链接更多精彩内容