java的List接口的实现类 ArrayList,LinkedList,Vector 的区别

Java的List接口有3个实现类,分别是ArrayList、LinkedList、Vector,他们用于存放多个元素,维护元素的次序,而且允许元素重复。

3个具体实现类的区别如下:

           1. ArrayList是最常用的List实现类,内部是通过数组实现的,它允许对元素进行快速随机访问。数组的缺点是每个元素之间不能有间隔,当数组大小不满足时需要增加存储能力,就要将已经有数组的数据复制到新的存储空间中。当从ArrayList的中间位置插入或者删除元素时,需要对数组进行复制、移动、代价比较高。因此,它适合随机查找和遍历,不适合插入和删除,允许空元素

           2. Vector与ArrayList一样,也是通过数组实现的,不同的是它支持线程的同步,即某一时刻只有一个线程能够写Vector,避免多线程同时写而引起的不一致性,但实现同步需要很高的花费,因此,访问它比访问ArrayList慢。

          3. LinkedList是用链表结构存储数据的,很适合数据的动态插入和删除,随机访问和遍历速度比较慢。另外,接口中没有定义的方法get,remove,insertList,专门用于操作表头和表尾元素,可以当作堆栈、队列和双向队列使用。LinkedList没有同步方法。如果多个线程同时访问一个List,则必须自己实现访问同步。一种解决方法是在创建 List时构造一个同步的List:
             List list = Collections.synchronizedList(new LinkedList(...));

查看Java源代码,发现当数组的大小不够的时候,需要重新建立数组,然后将元素拷贝到新的数组内,ArrayList和Vector的扩展数组的大小不同。

ArrayList中:

public boolean add(E e) {
 
     ensureCapacity(size + 1);  // 增加元素,判断是否能够容纳。不能的话就要新建数组
  
     elementData[size++] = e;
 
     return true;
 
 }
 
  public void ensureCapacity(int minCapacity) {
 
     modCount++; 
 
     int oldCapacity = elementData.length;
 
     if (minCapacity > oldCapacity) {
 
         Object oldData[] = elementData; // 此行没看出来用处,不知道开发者出于什么考虑
  
         int newCapacity = (oldCapacity * 3)/2 + 1; // 增加新的数组的大小
  
         if (newCapacity < minCapacity)
 
        newCapacity = minCapacity;
 
             // minCapacity is usually close to size, so this is a win:
  
             elementData = Arrays.copyOf(elementData, newCapacity);
 
     }
 
 }


 

Vector中:

private void ensureCapacityHelper(int minCapacity) {
 
     int oldCapacity = elementData.length;
 
     if (minCapacity > oldCapacity) {
 
         Object[] oldData = elementData;
 
         int newCapacity = (capacityIncrement > 0) ?
 
        (oldCapacity + capacityIncrement) : (oldCapacity * 2);
 
         if (newCapacity < minCapacity) {
 
        newCapacity = minCapacity;
 
         }
 
          elementData = Arrays.copyOf(elementData, newCapacity);
 
     }
 
 }


 

关于ArrayList和Vector区别如下:

             1. ArrayList在内存不够时默认是扩展50% + 1个,Vector是默认扩展1倍。

             2. Vector提供indexOf(obj, start)接口,ArrayList没有。

             3. Vector属于线程安全级别的,但是大多数情况下不使用Vector,因为线程安全需要更大的系统开销。

 

 

 

  • 5
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java中的ArrayListLinkedListVector是三种常见的集合,它们都实现List接口,但在实现和使用上有一些区别。 1. 实现方式: - ArrayList是基于数组实现的动态数组,可以动态调整数组的大小。 - LinkedList是基于链表实现的,每个元素都包含一个指向前一个和后一个元素的引用。 - Vector也是基于数组实现的动态数组,似于ArrayList,但是它是线程安全的。 2. 线程安全性: - ArrayListLinkedList不是线程安全的,多个线程同时访问时需要外部同步控制。 - Vector是线程安全的,它的每个方法都使用了synchronized关键字进行同步,可以在多线程环境下使用。 3. 性能: - ArrayList的性能比LinkedList好,因为它直接通过索引访问元素,而LinkedList需要遍历链表才能找到指定位置的元素。 - Vector由于需要进行同步控制,性能相对较差。 4. 插入和删除操作: - ArrayList在末尾插入和删除元素的性能较好,但在中间或开头插入和删除元素时,需要移动其他元素。 - LinkedList在任意位置插入和删除元素的性能较好,因为只需更改节点的引用。 5. 使用场景: - 如果需要频繁访问集合中的元素,并且对数据的增删操作较少,可以选择ArrayList。 - 如果需要频繁进行插入和删除操作,或者需要使用栈、队列等数据结构,可以选择LinkedList。 - 如果需要在多线程环境中使用,可以选择Vector。 总结:ArrayList适用于读取操作频繁的场景,LinkedList适用于频繁插入、删除操作的场景,Vector适用于多线程环境。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值