ArrayList和LinkedList的区别看这一篇就够了!

用一句话总结ArrayList和LinkedList的区别是:ArrayList底层是数组,查询快、增删慢;LinkedList底层是链表,查询慢、增删快。

但是,任何技术的好坏都是要看场景的...而且,LinkedList增删真的快吗?

关于ArrayList和LinkedList的区别,个人认为要结合底层数据结构来看查询和增删两个操作带来的影响。

查询比较

ArrayList底层是数组,数组的存储空间是连续的,可以根据寻址方式直接找到对应的元素位置,时间复杂度是O(1)。

举个例子:在一条正规有门牌的街上,你知道第一家店是001号,那么008肯定就在第8间,你直接过去就好了。啪一下,很快啊!

但LinkedList底层是链表,存储空间不连续,需要通过指针关联,在查询过程中需要不断跳转新的地址。

举个例子,可能不准确:你想要找一家网红店,结果到了店里,店员告诉你找错了,这是分店3号,并给了你总店的地址,你开车到了总店,结果经理又告诉你业务扩张太快了,这家已经不是总店了,总店在xx路100号...

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值