zoukankan      html  css  js  c++  java
  • Java 中的数据结构类 Vector 和 ArrayList

    今天刷算法题目时,使用到了 Java 的内置栈类 Stack,好奇它是怎么实现的,发现它是继承于 Vector 这个类。那么,就先学习下 Vector 这个类的实现吧!
    Vector 和 ArrayList 的区别大概等同于 HashTable 和HashMap 的区别,即:Vector 是 JDK 早期提供的动态数组类,支持动态扩容,内部方法使用了 synchronized 关键字保证了多线程的安全性;而 ArrayList 则未使用 synchronized 保证线程安全,故只能在单线程下使用。然后就是两者的动态扩容机制稍有不同,下面贴出来对比下:

    Vector
    
    private void grow(int minCapacity) {
        // overflow-conscious code
        int oldCapacity = elementData.length;
        int newCapacity = oldCapacity + ((capacityIncrement > 0) ?
                                         capacityIncrement : oldCapacity);
        if (newCapacity - minCapacity < 0)
            newCapacity = minCapacity;
        if (newCapacity - MAX_ARRAY_SIZE > 0)
            newCapacity = hugeCapacity(minCapacity);
        elementData = Arrays.copyOf(elementData, newCapacity);
    }
    

    Vector
    第一步,若增量 capacityIncrement 大于零,则使用增量 capacityIncrement;否则,在原大小的两倍;
    第二部,若执行完第一步后,新的容量还是未达到要求的容量,则直接使用要求的容量作为新的容量;

    ArrayList
    
    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 类没有增量字段 capacityIncrement。
    第一步,将容量提升至当前容量的 1.5 倍,若还未达到要求的容量,则直接使用要求的容量作为新的容量;

  • 相关阅读:
    JavaScript 显示数据
    c#运算符重载
    C++栈和队列标准库函数
    unity AB打包 unity2018.2.2
    VR AR SDK汇总
    Unity程序们经常用到的网址(方便自己用,一直更新)
    Unity打包Visual Studio部署HoloLens找不到WindowsMobile SDK的解决方案
    【Unity3D】串口通信
    【Unity3D】锁屏、解锁相关函数回调
    Unity3D Destroy方法的细节
  • 原文地址:https://www.cnblogs.com/optor/p/8540381.html
Copyright © 2011-2022 走看看