Java-Vector-01Vector底层实现原理及扩容方式

一、底层实现原理:数组(查询快,增删慢,线程安全)

1.成员变量

    /**
     * 可以看出实现原理是数组
     * @serial
     */
    protected Object[] elementData;

    /**
     * 
     * @serial
     */
    protected int elementCount;

    /**
     * 扩容长度,在有参构造时可以给该参数赋值,扩容时会将该参数和原来容量进行对比,取较大值再加上原                 
     * 来容量;无参构造,次参数值为赋值为0
     */
    protected int capacityIncrement;

2.构造方法

public Vector() {
        this(10);
    }
public Vector(int initialCapacity) {
        this(initialCapacity, 0);
    }
public Vector(int initialCapacity, int capacityIncrement) {
        super();
        if (initialCapacity < 0)
            throw new IllegalArgumentException("Illegal Capacity: "+
                                               initialCapacity);
        this.elementData = new Object[initialCapacity];
        this.capacityIncrement = capacityIncrement;
    }

3.扩容机制:

  扩容长度,在有参构造时可以给capacityIncrement赋值,扩容时会将capacityIncrement和原来容量进行对比,取较大值再加上原来容量(扩容机制相比ArrayList更灵活,开发者可以根据实际业务决定扩容,减少扩容的次数来提升性能);无参构造,次参数值为赋值为0

 public synchronized boolean add(E e) {
        modCount++;
        ensureCapacityHelper(elementCount + 1);
        elementData[elementCount++] = e;
        return true;
    }
  private void ensureCapacityHelper(int minCapacity) {
        // overflow-conscious code
        if (minCapacity - elementData.length > 0)
            grow(minCapacity);
    }
   
 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);
    }

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值