Java ArrayList & LinkedList 区别

Java ArrayList & LinkedList 区别

ArrayList

  • ArrayList底层是动态数组实现的,数组是一块连续的内存,是线程不安全的。
  • ArrayList会根据需要调整容量,每次扩容增加50%。
  • ArrayList内部元素以数组形式顺序存储,所以查询效率高。除了尾部插入和删除元素,其他位置性能较差,如我们在中间位置插入一个元素,需要移动后续所有元素。

LinkedList

  • LinkedList是Java提供的双向链表,所以不需要扩容,它也是线程不安全的。
  • LinkedList进行节点插入、删除高效很多,但是查询效率要低于动态数组。

SynchronizedList

SynchronizedList是线程安全的List,它的get、set、add等方法都使用synchronized同步支持。

List list = Collections.synchronizedList(new ArrayList<>());

ArrayList源码分析

LinkedList源码分析

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值