ICode9

精准搜索请尝试: 精确搜索
首页 > 编程语言> 文章详细

Vector源码解读

2022-04-05 12:34:01  阅读:177  来源: 互联网

标签:capacityIncrement Vector int elementData initialCapacity 解读 public minCapacity 


1.背景

阅读源码是提高编程技能的有效方式...

面试中也经常问到源码相关的问题.....

2.源码解读

在解读Vector时大家可以先解读ArrayList,因为这个两个的逻辑几乎是一样的....

ArrayList源码解读:https://www.cnblogs.com/newAndHui/p/16101626.html

区别在于

1.Vector的很多方法都是同步的即线程安全的,二ArrayList的很多方法时线程非同步的;

2.Vector扩容默认是原来的1倍,二ArrayList默认是按照原来的1.5倍扩容;

3.Vectory对象创建时默认数组长度为10,而ArrayList对象创建时是一个空数组,在添加第一个元素是才设置数组长度为10

阅读源码前自己写一个与Vector功能差不多的对象MyVector,相信你看懂了MyVector,那么Vector你就自然懂了...

package com.ldp.collection.my;

import java.util.AbstractList;
import java.util.Arrays;
import java.util.List;
import java.util.RandomAccess;

/**
 * @author 姿势帝-博客园
 * @address https://www.cnblogs.com/newAndHui/
 * @WeChat 851298348
 * @create 04/05 10:51
 * @description
 */
public class MyVector<E> extends AbstractList<E> implements List<E>, RandomAccess, Cloneable, java.io.Serializable {
    private static final long serialVersionUID = -2767605614048989439L;
    protected Object[] elementData; // 存放元素的数组对象
    protected int elementCount; // 存放的元素个数
    protected int capacityIncrement; // 数组扩容时的扩容量,默认为0,表示安装原来的1倍扩容,10扩容一次后为20
    private static final int MAX_ARRAY_SIZE = Integer.MAX_VALUE - 8;// 数组的最大容量

    /**
     * 无参数构造方法,默认容量为10
     */
    public MyVector() {
        this(10);
    }

    /**
     * 自定义容量的构造方法
     */
    public MyVector(int initialCapacity) {
        this(initialCapacity, 0);
    }

    /**
     * 自定义容量 和 扩容数的构造方法
     *
     * @param initialCapacity   数组长度
     * @param capacityIncrement 扩容时的增加长度,默认为0,安装原来的1倍扩容
     */
    public MyVector(int initialCapacity, int capacityIncrement) {
        super();
        if (initialCapacity < 0)
            throw new IllegalArgumentException("Illegal Capacity: " +
                    initialCapacity);
        this.elementData = new Object[initialCapacity];
        this.capacityIncrement = capacityIncrement;
    }

    /**
     * 线程安全的,所以很多操作方法都是加了 synchronized 关键字的
     */
    @Override
    public synchronized boolean add(E e) {
        // 累加修改次数
        modCount++;
        // 确定容量
        ensureCapacityHelper(elementCount + 1);
        // 在原来的元素后面加一个元素
        elementData[elementCount++] = e;
        return true;
    }

    private void ensureCapacityHelper(int minCapacity) {
        // 当最小需要的容量大于数组长度时进行扩容
        if (minCapacity - elementData.length > 0)
            grow(minCapacity);
    }

    private void grow(int minCapacity) {
        // 原来的容量
        int oldCapacity = elementData.length;
        // 新的容量,capacityIncrement=0时,newCapacity=oldCapacity+oldCapacity,即按照原来的1倍扩容
        int newCapacity = oldCapacity + ((capacityIncrement > 0) ? capacityIncrement : oldCapacity);
        // 加一倍后长度还是不够,则用传递过来的数值minCapacity(addAll来说,就是原长度+新集合长度)
        if (newCapacity - minCapacity < 0)
            newCapacity = minCapacity;
        // 超出最大值时计算
        if (newCapacity - MAX_ARRAY_SIZE > 0)
            newCapacity = hugeCapacity(minCapacity);
        // 执行扩容
        elementData = Arrays.copyOf(elementData, newCapacity);
    }

    private static int hugeCapacity(int minCapacity) {
        if (minCapacity < 0) // overflow
            throw new OutOfMemoryError();
        return (minCapacity > MAX_ARRAY_SIZE) ?
                Integer.MAX_VALUE :
                MAX_ARRAY_SIZE;
    }

    @Override
    public synchronized E get(int index) {
        if (index >= elementCount)
            throw new ArrayIndexOutOfBoundsException(index);

        return elementData(index);
    }

    @SuppressWarnings("unchecked")
    E elementData(int index) {
        return (E) elementData[index];
    }

    @Override
    public synchronized int size() {
        return elementCount;
    }
}

完美!

标签:capacityIncrement,Vector,int,elementData,initialCapacity,解读,public,minCapacity,
来源: https://www.cnblogs.com/newAndHui/p/16101869.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有