java vector实例_Java集合-06Vector源码解析及使用实例

Vector简介

Vector (矢量类)实现了动态数组的功能,如同数组,它可以通过角标访问数据,

不过Vector被创建后在添加或移除时候能适应性的增加或者减少。继承AbstractCollection类,实现了List、RandomAccess、Cloneable、Serialization接口

构造方法

public Vector()

public Vector(int initialCapacity)

public Vector(int initialCapacity, int capacityIncrement)

Vector包含三个构造函数,第一种默认构造函数,此时初始容量为10,

第二种指定容量大小的构造函数,此时capacityIncrement等于0,扩容时候成倍增加,

第三种指定容量大小和增量,扩容时候增加capacityIncrement大小

重要属性

protected Object[] elementData;//用于保存Vector数据的数组

protected int elementCount;//Vector中数据个数

protected int capacityIncrement;//Vector容器的增量

Vector的方法和ArrayList类似,不过它的增删改查方法前都添加synchronized修饰,保证线程安全,也就是说Vector是线程同步的

Vector源码分析

public synchronized boolean add(E e) {

modCount++;//fail-fast判断机制

ensureCapacityHelper(elementCount + 1);//确保Vector容量足够,跳转到下一个方法

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);//如果增量大于0,扩容后的大小为原来容量与增量的和,否则扩容为原来容量的一倍

if (newCapacity - minCapacity < 0)

newCapacity = minCapacity;

if (newCapacity - MAX_ARRAY_SIZE > 0)

newCapacity = hugeCapacity(minCapacity);

elementData = Arrays.copyOf(elementData, newCapacity);

}

public synchronized E remove(int index) {

modCount++;//fail-fast

if (index >= elementCount)

throw new ArrayIndexOutOfBoundsException(index);//数组角标过界异常

E oldValue = elementData(index);//获取当前角标位置的元素数据

int numMoved = elementCount - index - 1;

if (numMoved > 0)

System.arraycopy(elementData, index+1, elementData, index,numMoved);//复制数组(复制源数组,复制源数组开始位置,复制数组,复制数组开始位置,复制长度)

elementData[--elementCount] = null; // Let gc do its work

return oldValue;

}

Vector遍历方式

Vectorvect = new Vector<>(10);

迭代器遍历

Iterator iterator = vect.iterator();

while (iterator.hasNext()){

iterator.next();

}

forEach遍历

for (String s : vect) {

}

RandomAccess遍历

for (int i = 0;i

vect.get(i);

}

Enumeration遍历

Enumeration elements = vect.elements();

while (elements.hasMoreElements()){

elements.nextElement();

}

Vector使用实例

使用实例代码在Github上

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值