LinkedList

ArrayList简介

        ArrayList是一个基于双向链表实现的集合,由于无法对元素进行随机访问,LinkedList 仅仅在头尾插入或者删除元素的时候时间复杂度近似 O(1),其他情况增删元素需要移动到指定位置,平均时间复杂度都是 O(n)。ArrayList的性能通常会比LinkedList更好,所以不要下意识地认为 LinkedList 作为链表就最适合元素增删的场景。

LinkedList类图

         由类图我们可以知道LinkedList同样继承了 AbstractList,因此 LinkedList 会有大部分方法和 ArrayList 相似。同时,其支持深浅拷贝,序列化操作,并且具有双端队列的特性。

为什么LinkedList不支持随机访问?

        LinkedList底层数据结构是一个双向链表,内存地址并不是连续的,不支持随机访问。

获取元素

 调用get(int index)函数获取链表指定位置的元素,其内部调用了node(int index)函数,该方法通过比较索引值与链表的一半大小来确定从链表头还是尾开始遍历。充分利用了双向链表的特性来提高效率。

遍历列表

         使用for-each 循环来遍历 LinkedList 中的元素时,for-each 循环最终会转换成迭代器形式 。 迭代器在遍历列表时会比较exceptedModCount和链表的modCount,以此判断链表是否被其他的线程修改过。在遍历过程中,如果要对链表执行删除或添加元素操作,应该使用迭代器进行操作,否则迭代器会抛出异常。

   

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
LinkedListJava中的一个类,它实现了List接口和Deque接口,可以被看作是一个顺序容器、队列和栈。LinkedList的遍历过程和查找过程类似,可以从头节点开始往后遍历。然而,LinkedList不擅长随机位置访问,如果使用随机访问遍历LinkedList,效率会很低。通常情况下,我们会使用foreach循环来遍历LinkedList,因为foreach最终会转换成迭代器形式。LinkedList的遍历核心就是它的迭代器实现。[1] LinkedList的继承体系较为复杂,它继承自AbstractSequentialList类,并实现了List和Deque接口。AbstractSequentialList是一个基于顺序访问的接口,通过继承此类,子类只需实现部分代码即可拥有完整的一套访问某种序列表的接口。LinkedList还实现了Deque接口,Deque又继承自Queue接口,因此LinkedList具备了队列的功能。[2][3] LinkedList的实现方式决定了所有与下标有关的操作都是线性时间复杂度,而在首段或末尾删除元素只需要常数时间复杂度。LinkedList没有实现同步(synchronized),如果需要多个线程并发访问,可以使用Collections.synchronizedList()方法对其进行包装。[2] 总结来说,LinkedList是一个灵活的数据结构,可以用作顺序容器、队列和栈。它的遍历过程需要注意效率问题,不适合随机位置访问LinkedList的继承体系较为复杂,继承自AbstractSequentialList类,并实现了List和Deque接口。LinkedList的实现方式决定了与下标有关的操作是线性时间复杂度,而在首段或末尾删除元素只需要常数时间复杂度。[1][2][3]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值