目录

一.前言

1.1vector简介

1.1.1java Collection下的子类图

1.1..2 介绍

1.1.3Vector类详细规则

1.2Vector与ArrayList的区别

二.Vector的方法

 三.代码示例(demo)


一.前言

1.1vector简介

1.1.1java Collection下的子类图

java vector 源码 java中的vector_java vector 源码

1.1..2 介绍

  Vector类 是在 java 中可以实现自动增长的对象数组

  Java中Vector类是允许不同类型元素共存的变长数组,Java.util.Vector提供了向量(Vector)类以实现类似动态数组的功能。在Java中是没有zhizheng 概念的,但如果能正确灵活地使用指针又确实可以大大提高程序的质量,比如在C、C++中所谓“动态数组”一般都由指针来实现。为了弥补这点缺陷,Java提供了丰富的类库来方便编程者使用,Vector类便是其中之一。事实上,灵活使用数组也可完成向量类的功能,向量类中提供的大量方法也大大方便了用户的使用。

1.1.3Vector类详细规则

  在相对于ArrayList来说,Vector线程是安全的,也就是说是同步的。创建了一个向量类的对象后,可以往其中随意地插入不同的类的对象,既不需顾及类型也不需预先选定向量的容量,并可方便地进行查找。对于预先不知或不愿预先定义数组大小,并需频繁进行查找、插入和删除工作的情况,可以考虑使用向量类。向量类提供了种构造方法:

//第一种构造方法创建一个默认的向量,默认大小为 10:
Vector()
//第二种构造方法创建指定大小的向量。
Vector(int size)
//第三种构造方法创建指定大小的向量,并且增量用 incr 指定。增量表示向量每次增加的元素数目。
Vector(int size,int incr)
//第四种构造方法创建一个包含集合 c 元素的向量:
Vector(Collection c)



参数capacityIncrement给定了每次扩充的扩充值。当capacityIncrement为0时,则每次扩充一倍。利用这个功能可以优化存储。在Vector类中提供了各种方法方便用户使用:

1.2Vector与ArrayList的区别


1. 线程安全: Vector 使⽤了 Synchronized 来实现线程同步,是线程安全的,⽽ ArrayList 是⾮线程安全的。


2.性能: ArrayList 在性能⽅⾯要优于 Vector 。


3.扩容: ArrayList 和 Vector 都会根据实际的需要动态的调整容量,只不过在 Vector 扩容每次会增


加 1 倍,⽽ ArrayList 只会增加 50% 。



二.Vector的方法


序号

方法描述

1

void add(int index, Object element) 

 在此向量的指定位置插入指定的元素。

2

boolean add(Object o) 

 将指定元素添加到此向量的末尾。

3

boolean addAll(Collection c) 

将指定 Collection 中的所有元素添加到此向量的末尾,按照指定 collection 的迭代器所返回的顺序添加这些元素。

4

boolean addAll(int index, Collection c) 

在指定位置将指定 Collection 中的所有元素插入到此向量中。

5

void addElement(Object obj) 

 将指定的组件添加到此向量的末尾,将其大小增加 1。

6

int capacity() 

返回此向量的当前容量。

7

void clear() 

从此向量中移除所有元素。

8

Object clone() 

返回向量的一个副本。

9

boolean contains(Object elem) 

如果此向量包含指定的元素,则返回 true。

10

boolean containsAll(Collection c) 

如果此向量包含指定 Collection 中的所有元素,则返回 true。

11

void copyInto(Object[] anArray) 

 将此向量的组件复制到指定的数组中。

12

Object elementAt(int index) 

返回指定索引处的组件。

13

Enumeration elements() 

返回此向量的组件的枚举。

14

void ensureCapacity(int minCapacity) 

增加此向量的容量(如有必要),以确保其至少能够保存最小容量参数指定的组件数。

15

boolean equals(Object o) 

比较指定对象与此向量的相等性。

16

Object firstElement() 

返回此向量的第一个组件(位于索引 0) 处的项)。

17

Object get(int index) 

返回向量中指定位置的元素。

18

int hashCode() 

返回此向量的哈希码值。

19

int indexOf(Object elem) 

 返回此向量中第一次出现的指定元素的索引,如果此向量不包含该元素,则返回 -1。

20

int indexOf(Object elem, int index) 

 返回此向量中第一次出现的指定元素的索引,从 index 处正向搜索,如果未找到该元素,则返回 -1。

21

void insertElementAt(Object obj, int index) 

将指定对象作为此向量中的组件插入到指定的 index 处。

22

boolean isEmpty() 

测试此向量是否不包含组件。

23

Object lastElement() 

返回此向量的最后一个组件。

24

int lastIndexOf(Object elem) 

 返回此向量中最后一次出现的指定元素的索引;如果此向量不包含该元素,则返回 -1。

25

int lastIndexOf(Object elem, int index) 

返回此向量中最后一次出现的指定元素的索引,从 index 处逆向搜索,如果未找到该元素,则返回 -1。

26

Object remove(int index) 

 移除此向量中指定位置的元素。

27

boolean remove(Object o) 

移除此向量中指定元素的第一个匹配项,如果向量不包含该元素,则元素保持不变。

28

boolean removeAll(Collection c) 

从此向量中移除包含在指定 Collection 中的所有元素。

29

void removeAllElements() 

从此向量中移除全部组件,并将其大小设置为零。

30

boolean removeElement(Object obj) 

从此向量中移除变量的第一个(索引最小的)匹配项。

31

void removeElementAt(int index) 

删除指定索引处的组件。

32

protected void removeRange(int fromIndex, int toIndex)

从此 List 中移除其索引位于 fromIndex(包括)与 toIndex(不包括)之间的所有元素。

33

boolean retainAll(Collection c) 

在此向量中仅保留包含在指定 Collection 中的元素。

34

Object set(int index, Object element)

 用指定的元素替换此向量中指定位置处的元素。

35

void setElementAt(Object obj, int index) 

将此向量指定 index 处的组件设置为指定的对象。

36

void setSize(int newSize) 

 设置此向量的大小。

37

int size() 

 返回此向量中的组件数。

38

List subList(int fromIndex, int toIndex) 

返回此 List 的部分视图,元素范围为从 fromIndex(包括)到 toIndex(不包括)。

39

Object[] toArray()

 返回一个数组,包含此向量中以恰当顺序存放的所有元素。

40

Object[] toArray(Object[] a) 

返回一个数组,包含此向量中以恰当顺序存放的所有元素;返回数组的运行时类型为指定数组的类型。

41

String toString() 

返回此向量的字符串表示形式,其中包含每个元素的 String 表示形式。

42

void trimToSize() 

  对此向量的容量进行微调,使其等于向量的当前大小。


 三.代码示例(demo)

demo

import java.util.Enumeration;
import java.util.Vector;

/**
 * <pre>
 *     Vector 小demo
 * </pre>
 */
public class Demo2 {
    public static void main(String[] args) {
        // 初始大小为3,增量为2
        Vector v = new Vector(3, 2);
        //初始大小
        System.out.println("初始化大小: " + v.size());
        //初始容量
        System.out.println("初始容量 : " + v.capacity());
        //扩容
        v.addElement(new Integer(1));
        v.addElement(new Integer(2));
        v.addElement(new Integer(3));
        v.addElement(new Integer(4));
        v.addElement(new Integer(5));
        System.out.println("五次增加后的容量: " + v.capacity());


        //当前容量
        v.addElement(new Double(5.45));
        System.out.println("当前容量: " + v.capacity());
        v.addElement(new Double(6.08));
        v.addElement(new Integer(7));
        System.out.println("当前容量:: " + v.capacity());
        v.addElement(new Float(9.4));
        v.addElement(new Integer(10));
        System.out.println("当前容量:: " + v.capacity());


        v.addElement(new Integer(11));
        v.addElement(new Integer(12));
        //首元素
        System.out.println("首元素: " + (Integer) v.firstElement());
        //尾元素
        System.out.println("尾元素: " + (Integer) v.lastElement());

        if (v.contains(new Integer(3)))
            System.out.println("Vector 包含 3.");
        // vector中的元素
        Enumeration vEnum = v.elements();
        System.out.println("Vector中的元素:");
        while (vEnum.hasMoreElements())
            System.out.print(vEnum.nextElement() + " ");
        System.out.println();
    }
}

代码输出

java vector 源码 java中的vector_java_02