首先看这两类都实现List接口,而List接口一共同拥有三个实现类。各自是ArrayList、Vector和LinkedList。List用于存放多个元素,可以维护元素的次序,而且同意元素的反复。

3个详细实现类的相关差别例如以下:



1.ArrayList是最经常使用的List实现类,内部是通过数组实现的,它同意对元素进行高速随机訪问。数组的缺点是每一个元素之间不能有间隔,当数组大小不满足时须要添加存储能力。就要讲已经有数组的数据拷贝到新的存储空间中。当从ArrayList的中间位置插入或者删除元素时,须要对数组进行复制、移动、代价比較高。

因此,它适合随机查找和遍历,不适合插入和删除。



2.Vector与ArrayList一样,也是通过数组实现的,不同的是它支持线程的同步,即某一时刻仅仅有一个线程可以写Vector。避免多线程同一时候写而引起的不一致性,但实现同步须要非常高的花费,因此。訪问它比訪问ArrayList慢。



3.LinkedList是用链表结构存储数据的,非常适合数据的动态插入和删除,随机訪问和遍历速度比較慢。另外,他还提供了List接口中未定义的方法,专门用于操作表头和表尾元素。能够当作堆栈、队列和双向队列使用。



查看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,由于线程安全须要更大的系统开销。

Java中Vector与ArrayList的差别具体解释的更多相关文章

  1. Java 中 Vector、ArrayList、List 使用深入剖析

    线性表,链表,哈希表是常用的数据结构,在进行Java开发时,JDK已经为我们提供了一系列相应的类来实现基本的数据结构.这些类均在java.util包中.本文试图通过简单的描述,向读者阐述各个类的作用以 ...

  2. Java中Vector和ArrayList的区别

    首先看这两类都实现List接口,而List接口一共有三个实现类,分别是ArrayList.Vector和LinkedList.List用于存放多个元素,能够维护元素的次序,并且允许元素的重复.3个具体 ...

  3. 【转】Java中Vector和ArrayList的区别

    首先看这两类都实现List接口,而List接口一共有三个实现类,分别是ArrayList.Vector和LinkedList.List用于存放多个元素,能够维护元素的次序,并且允许元素的重复.3个具体 ...

  4. Java 中 Vector、ArrayList、List 使用深入剖析【转载】

    线性表,链表,哈希表是常用的数据结构,在进行Java开发时,JDK已经为我们提供了一系列相应的类来实现基本的数据结构.这些类均在java.util包中.本文试图通过简单的描述,向读者阐述各个类的作用以 ...

  5. Java 中 Vector 和 ArrayList 的区别

    首先看这两类都实现List接口,而List接口一共有三个实现类,分别是ArrayList.Vector和LinkedList.List用于存放多个元素,能够维护元素的次序,并且允许元素的重复.3个具体 ...

  6. java中vector、ArrayList、LinkedList的区别

    转 首先看这两类都实现List接口,而List接口一共有三个实现类,分别是ArrayList.Vector和LinkedList.List用于存放多个元素,能够维护元素的次序,并且允许元素的重复.3个 ...

  7. Java中List,ArrayList、Vector,map,HashTable,HashMap区别用法

    Java中List,ArrayList.Vector,map,HashTable,HashMap区别用法 标签: vectorhashmaplistjavaiteratorinteger ArrayL ...

  8. Java-杂项: Java中Array和ArrayList区别

    ylbtech-Java-杂项: Java中Array和ArrayList区别 1.返回顶部 1. 1)精辟阐述:可以将 ArrayList想象成一种“会自动扩增容量的Array”. 2)Array( ...

  9. java中vector与hashtable操作详解

    众所周知,java中vector与hashtable是线程安全的,主要是java对两者的操作都加上了synchronized,也就是上锁了.因此 在vector与hashtable的操作是不会出现问题 ...

随机推荐

  1. MVC架构中的controller的几种写法

    开始写代码之前,我们先来看一下spring MVC概念.一张图能够清晰得说明. 除了controller,我们需要编写大量代码外,其余的都可以通过配置文件直接配置. MVC的本质即是将业务数据的抽取和 ...

  2. times、 time、clock函数说明

    sysconf( _SC_CLK_TCK )  功能  获取系统的 时钟滴答的频率. clock_gettime() clock()返回的是各个线程运行cpu时间的和, 返回值一直都是0. 定义函数: ...

  3. PO/POJO/BO/DTO/VO的区别(转)

    PO :persistent object持久对象 1 .有时也被称为Data对象,对应数据库中的entity,可以简单认为一个PO对应数据库中的一条记录. 2 .在hibernate持久化框架中与i ...

  4. codeforces-455A

    题目连接:http://codeforces.com/contest/455/problem/A A. Boredom time limit per test 1 second memory limi ...

  5. HDU 2612 Find a way【多起点多终点BFS/两次BFS】

    Find a way Time Limit: 3000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total Su ...

  6. RPD Volume 172 Issue 1-3 December 2016 评论01

    Evaluation of Imaging Dose From Different Image Guided Systems During Head and Neck Radiotherapy: A ...

  7. Cent OS 运行 Cuberite

    Cuberite 是一个轻量级的Minecraft服务端,由C++编写,性能比Mojang等等用java写的高很多. 在腾讯云的最低端VPS上,用Spigot建服的话,从主世界传送到下界用时要五六秒的 ...

  8. Codeforces 788C The Great Mixing(背包问题建模+bitset优化或BFS)

    [题目链接] http://codeforces.com/problemset/problem/788/C [题目大意] 给出一些浓度的饮料,要求调出n/1000浓度的饮料,问最少需要多少升饮料 [题 ...

  9. 【二分答案】【字符串哈希】bzoj2084 [Poi2010]Antisymmetry

    显然只有偶数长度的串符合题意,并且如果一个串符合题意,那么从其首尾各截掉一个字符也符合题意. 于是枚举中心,二分可以向左右扩展的最远距离,累计答案. #include<cstdio> #i ...

  10. 【费马小定理+矩阵快速幂】HDU4549——M斐波那契数列

    [题目大意] M斐波那契数列F[n]是一种整数数列,它的定义如下:F[0] = aF[1] = bF[n] = F[n-1] * F[n-2] ( n > 1 )现在给出a, b, n,求出F[ ...