ArrayList和LinkedList的相爱相杀

ArrayList:

  • 基于动态数据实现  
  • 向集合中添加 删除元素效率低
  • 在集合中根据索引查找元素效率高
  • 线程不安全【如何解决线程不安全的问题】

ArrayList如何实现动态扩容:

因为ArrayList基于数组实现的,所有ArrayList的扩容就是数组的扩容。

看下源码即可以知道默认开辟的数长度为10:

​
private static final int DEFAULT_CAPACITY = 10;

扩容的规则是每次扩大当前数组的一半

 private void grow(int minCapacity) {
        // overflow-conscious code
        int oldCapacity = elementData.length;
        int newCapacity = oldCapacity + (oldCapacity >> 1);
        if (newCapacity - minCapacity < 0)
            newCapacity = minCapacity;
        if (newCapacity - MAX_ARRAY_SIZE > 0)
            newCapacity = hugeCapacity(minCapacity);
        // minCapacity is usually close to size, so this is a win:
        elementData = Arrays.copyOf(elementData, newCapacity);
    }

ArrayList的equals方法:

  1. 先判断是否为自己和自己比
  2. 然后用instanceof判断是否为List的子实现
  3. 然后使用迭代器listIterator的hasNext()方法和next()方法循环遍历两个集合中的元素是否相等
public boolean equals(Object o) {
        if (o == this)
            return true;
        if (!(o instanceof List))
            return false;

        ListIterator<E> e1 = listIterator();
        ListIterator<?> e2 = ((List<?>) o).listIterator();
        while (e1.hasNext() && e2.hasNext()) {
            E o1 = e1.next();
            Object o2 = e2.next();
            if (!(o1==null ? o2==null : o1.equals(o2)))
                return false;
        }
        return !(e1.hasNext() || e2.hasNext());
    }

 

 


 

 


LinkedList:

  • 基于队列链表实现
  • 向集合中添加 删除元素效率高
  • 在集合中查找元素效率低 
  • 线程不安全

 

 

 

下面是我做的关于ArrayListLinkedList添加操作的时间对比Demo:

public static void main(String[] args) throws InterruptedException {
		
		
		
		List<String> arrayList = new ArrayList<>();
		
		List<String> linkedList = new LinkedList<>();
		
		for (int i = 0; i < 11000000; i++) {
			arrayList.add(i+"");
		}
		
		for (int i = 0; i < 11000000; i++) {
			linkedList.add(i+"");
		}
		
		
		long starTime = System.currentTimeMillis();
		arrayList.add(1,"*");
		long endTime = System.currentTimeMillis();
		System.out.println("ArrayList添加时间:"+(endTime - starTime));
		
		
		long starTime1 = System.currentTimeMillis();
		linkedList.add(1,"*");
		long endTime1 = System.currentTimeMillis();
		System.out.println("LingkedList添加时间1:"+(endTime1 - starTime1));

	}

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值