LinkedList PK ArrayList

LinkedList 和 ArrayList 都实现了List 接口
Collection结构
在这里插入图片描述插入操作
默认顺序插入,两者的时间都是O(1)
指定index插入元素:1、ArrayList 最坏情况性能O(n),最好情况是(容量不够时,需要扩容)O(1) ArrayList扩容机制
2.LinkedList 在都是O(1)

删除操作
1、ArrayList 删除操作最坏情况下性能是O(n),最好O(1),删除最后一个元素性能O(1)
2、LinkedList 删除元素操作时性能都是O(1)
搜索操作
ArrayList 搜索性能为O(1)
LinkedList 搜索性能差一些,为O(n/2)
总结

  • LinkedList因为要同时维护邻居节点的两个指针,内存消耗大于ArrayList
  • 频繁操作插入删除的时候,LinkedList性能好
  • 在频繁操作搜索时,ArrayList性能好
  • 她们线程都是不安全的。可以通过下面方法实现线程安全

List list = Collections.synchronizedList(new ArrayList()); …
synchronized(list) {
Iterator i = list.iterator(); // 必须在 synchronized 块中
while (i.hasNext())
foo(i.next()); }

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值