ArrayList 和 LinkedList区别 以及 ArrayList集合知识点总结

ArrayList和LinkedList的区别,各个基本操作的复杂度是多少,方法是什么,ArrayList的底层结构是什么,如果数组容量不够怎么办,扩容之后get的复杂度是多少…
这里写图片描述
**答:**ArrayList与LinkedList都是List接口的实现类, List是一个接口又继承了Collection接口。

ArrayList: get() 、add()、remove()
LinkedList: 独有方法addFirst()、addLast()、getFirst()、getLast()、removeFirst()、removeLast()

区别:

1、 底层实现角度。
ArrayList:是基于动态数组的数据结构;名称是elementData,类型是Object[],所以ArrayList里面可以存放任意类型的元素
LinkedList:是基于双向循环链表的数据结构

2、 随机访问(索引)元素角度。get
ArrayList:数据存储是连续的,因此支持用下标来访问元素get(int index),直接返回index位置上的元素,随机访问元素速度快 O(1)
LinkedList:需要通过for循环进行查找,虽然LinkedList已经在查找方法上做了优化,比如index < size / 2,则从左边开始查找,反之从右边

  • 2
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值