所有类


java.util
类 Vector<E>

java.lang.Object
  继承者 java.util.AbstractCollection<E>
      继承者 java.util.AbstractList<E>
          继承者 java.util.Vector<E>
所有已实现的接口:
Serializable, Cloneable, Iterable<E>, Collection<E>, List<E>, RandomAccess
直接已知子类:
Stack

public class Vector<E>
   
   
   
   
   
extends AbstractList<E>
implements List<E>, RandomAccess, Cloneable, Serializable

Vector 类可以实现可增长的对象数组。与数组一样,它包含可以使用整数索引进行访问的组件。但是,Vector 的大小可以根据需要增大或缩小,以适应创建 Vector 后进行添加或移除项的操作。

每个向量会试图通过维护 capacitycapacityIncrement 来优化存储管理。capacity 始终至少应与向量的大小相等;这个值通常比后者大些,因为随着将组件添加到向量中,其存储将按 capacityIncrement 的大小增加存储块。应用程序可以在插入大量组件前增加向量的容量;这样就减少了增加的重分配的量。

从 Java 2 平台 v1.2 开始,已改进此类以实现 List,这样它就成为了 Java 的集合框架的一部分。与新集合的实现不同,Vector 是同步的。

由 Vector 的 iterator 和 listIterator 方法所返回的迭代器是快速失败的:如果在迭代器创建后的任意时间从结构上修改了向量(通过迭代器自身的 remove 或 add 方法之外的任何其他方式),则迭代器将抛出 ConcurrentModificationException。因此,面对并发的修改,迭代器很快就完全失败,而不是冒着在将来不确定的时间任意发生不确定行为的风险。Vector 的 elements 方法返回的 Enumeration 不是 快速失败的。

注意,迭代器的快速失败行为不能得到保证,一般来说,存在不同步的并发修改时,不可能作出任何坚决的保证。快速失败迭代器尽最大努力抛出 ConcurrentModificationException。因此,编写依赖于此异常的程序的方式是错误的,正确做法是:迭代器的快速失败行为应该仅用于检测 bug。

此类是 Java Collections Framework 的成员。

从以下版本开始:
JDK1.0
另请参见:
Collection, List, ArrayList, LinkedList, 序列化表格

字段摘要
protected  intcapacityIncrement
          向量的大小大于其容量时,容量自动增加的量。
protected  intelementCount
          Vector 对象中的有效组件数。
protected  Object[]elementData
          存储向量组件的数组缓冲区。
 
从类 java.util.AbstractList 继承的字段
modCount
 
构造方法摘要
Vector()
          构造一个空向量,使其内部数据数组的大小为 10,其标准容量增量为零。
Vector(Collection<? extends E> c)
          构造一个包含指定集合中的元素的向量,这些元素按其集合的迭代器返回元素的顺序排列。
Vector(int initialCapacity)
          使用指定的初始容量和等于零的容量增量构造一个空向量。
Vector(int initialCapacity, int capacityIncrement)
          使用指定的初始容量和容量增量构造一个空的向量。
 
方法摘要
 booleanadd(E o)
          将指定元素追加到此向量的末尾。
 voidadd(int index, E element)
          在此向量的指定位置插入指定的元素。
 booleanaddAll(Collection<? extends E> c)
          将指定 Collection 中的所有元素追加到此向量的末尾,按照指定集合的迭代器所返回的顺序追加这些元素。
 booleanaddAll(int index, Collection<? extends E> c)
          在指定位置将指定 Collection 中的所有元素插入到此向量中。
 voidaddElement(E obj)
          将指定的组件添加到此向量的末尾,将其大小增加 1。
 intcapacity()
          返回此向量的当前容量。
 voidclear()
          从此向量中移除所有元素。
 Objectclone()
          返回向量的一个副本。
 booleancontains(Object elem)
          测试指定的对象是否为此向量中的组件。
 booleancontainsAll(Collection<?> c)
          如果此向量包含指定 Collection 中的所有元素,则返回 true。
 voidcopyInto(Object[] anArray)
          将此向量的组件复制到指定的数组中。
 EelementAt(int index)
          返回指定索引处的组件。
 Enumeration<E>elements()
          返回此向量的组件的枚举。
 voidensureCapacity(int minCapacity)
          增加此向量的容量(如有必要),以确保其至少能够保存最小容量参数指定的组件数。
 booleanequals(Object o)
          比较指定对象与此向量的相等性。
 EfirstElement()
          返回此向量的第一个组件(位于索引 0 处的项)。
 Eget(int index)
          返回向量中指定位置的元素。
 inthashCode()
          返回此向量的哈希码值。
 intindexOf(Object elem)
          搜索给定参数的第一个匹配项,使用 equals 方法测试相等性。
 intindexOf(Object elem, int index)
          搜索给定参数的第一个匹配项,从 index 处开始搜索,并使用 equals 方法测试其相等性。
 voidinsertElementAt(E obj, int index)
          将指定对象作为此向量中的组件插入到指定的 index 处。
 booleanisEmpty()
          测试此向量是否不包含组件。
 ElastElement()
          返回此向量的最后一个组件。
 intlastIndexOf(Object elem)
          返回指定的对象在此向量中最后一个匹配项的索引。
 intlastIndexOf(Object elem, int index)
          向后搜索指定的对象,从指定的索引处开始搜索,并返回一个索引。
 Eremove(int index)
          移除此向量中指定位置的元素。
 booleanremove(Object o)
          移除此向量中指定元素的第一个匹配项,如果向量不包含该元素,则元素保持不变。
 booleanremoveAll(Collection<?> c)
          从此向量中移除包含在指定 Collection 中的所有元素。
 voidremoveAllElements()
          从此向量中移除全部组件,并将其大小设置为零。
 booleanremoveElement(Object obj)
          从此向量中移除变量的第一个(索引最小的)匹配项。
 voidremoveElementAt(int index)
          删除指定索引处的组件。
protected  voidremoveRange(int fromIndex, int toIndex)
          从此 List 中移除其索引位于 fromIndex(包括)与 toIndex(不包括)之间的所有元素。
 booleanretainAll(Collection<?> c)
          在此向量中仅保留包含在指定 Collection 中的元素。
 Eset(int index, E element)
          用指定的元素替换此向量中指定位置处的元素。
 voidsetElementAt(E obj, int index)
          将此向量指定 index 处的组件设置为指定的对象。
 voidsetSize(int newSize)
          设置此向量的大小。
 intsize()
          返回此向量中的组件数。
 List<E>subList(int fromIndex, int toIndex)
          返回此 List 的部分视图,元素范围为从 fromIndex(包括)到 toIndex(不包括)。
 Object[]toArray()
          返回一个数组,包含此向量中以正确顺序存放的所有元素。
<T> T[]
toArray(T[] a)
          返回一个数组,包含此向量中以正确顺序存放的所有元素;返回数组的运行时类型为指定数组的类型。
 StringtoString()
          返回此向量的字符串表示形式,其中包含每个元素的 String 表示形式。
 voidtrimToSize()
          对此向量的容量进行微调,使其等于向量的当前大小。
 
从类 java.util.AbstractList 继承的方法
iterator, listIterator, listIterator
 
从类 java.lang.Object 继承的方法
finalize, getClass, notify, notifyAll, wait, wait, wait
 
从接口 java.util.List 继承的方法
iterator, listIterator, listIterator
 

字段详细信息

elementData

protected Object[] elementData
存储向量组件的数组缓冲区。vector 的容量就是此数据缓冲区的长度,该长度至少要足以包含向量的所有元素。

Vector 中的最后一个元素后的任何数组元素都为 null。


elementCount

protected int elementCount
Vector 对象中的有效组件数。从 elementData[0]elementData[elementCount-1] 的组件均为实际项。


capacityIncrement

protected int capacityIncrement
向量的大小大于其容量时,容量自动增加的量。如果容量的增量小于或等于零,则每次需要增大容量时,向量的容量将增大一倍。

构造方法详细信息

Vector

public Vector(int initialCapacity,
              int capacityIncrement)
使用指定的初始容量和容量增量构造一个空的向量。

参数:
initialCapacity - 向量的初始容量。
capacityIncrement - 当向量溢出时容量增加的量。
抛出:
IllegalArgumentException - 如果指定的初始容量为负数。

Vector

public Vector(int initialCapacity)
使用指定的初始容量和等于零的容量增量构造一个空向量。

参数:
initialCapacity - 向量的初始容量。
抛出:
IllegalArgumentException - 如果指定的初始容量为负数。

Vector

public Vector()
构造一个空向量,使其内部数据数组的大小为 10,其标准容量增量为零。


Vector

public Vector(Collection<? extends E> c)
构造一个包含指定集合中的元素的向量,这些元素按其集合的迭代器返回元素的顺序排列。

参数:
c - 其元素要放入此向量中的集合。
抛出:
NullPointerException - 如果指定的集合为 null。
从以下版本开始:
1.2
方法详细信息

copyInto

public void copyInto(Object[] anArray)
将此向量的组件复制到指定的数组中。此向量中索引 k 处的项将复制到 anArray 的组件 k 中。数组必须足够大,能够保存此向量中的所有对象,否则抛出 IndexOutOfBoundsException

参数:
anArray - 要将组件复制到其中的数组。
抛出:
NullPointerException - 如果给定的数组为 null。

trimToSize

public void trimToSize()
对此向量的容量进行微调,使其等于向量的当前大小。如果此向量的容量大于其当前大小,则通过将其内部数据数组(保存在字段 elementData 中)替换为一个较小的数组,从而将容量更改为等于当前大小。应用程序可以使用此操作最小化向量的存储。