Vector与ArrayList都是List接口的实现类,它们都代表数组形式的数据结构。但是,它们的实现和使用场景却有所区别。
它们二者的实现非常相似,都是用一个对象数组来存储元素的。但是,Vector的大多数成员方法都会加上synchronized关键字,也就是说Vector线程是安全的。
由于Vector操作成员的方法必须保证同步,因此它的执行效率没有ArrayList高。所以,一般情况下,只有在必须保证同步的地方才会使用Vector,而大多数情况下,使用ArrayList更适合一些。
它们俩者的作用比较类似,一般通过add()方法来添加元素;remove()方法删除元素,size()方法得到集合元素的数量等。
示例代码如下:
public class Test4 {
public static void main(String[] args) {
Vector<String>v=new Vector<>();
v.add("hello");
v.remove("hello");
System.out.println(v.size());
ArrayList<String>a=new ArrayList<>();
a.add("hello");
a.remove("hello");
System.out.println(a.size());
}
}
运行结果为:
0
0
总结:
Vector是线程安全的,因为它操作元素的方法都是同步方法,而ArrayList不是。开发过程中应该根据需要进行选择,如果需要保证线程安全的地方则需要使用Vector,而不必要的时候则无需使用Vector们因为ArrayList效率会更高一些。