Vector和ArrayList的区别

区别:

(1)Vector的方法都是同步的(Synchronized),是线程安全的(thread-safe),而ArrayList的方法不是,由于线程的同步必然要影响性能,因此,ArrayList的性能比Vector要好一点。 
(2)两者都是用数组来实现的,当Vector或ArrayList中的元素超过它的初始大小时,Vector会将它的容量翻倍,而ArrayList只增加50%的大小,这样,ArrayList就有利于节约内存空间。

建议:

    只要不需要同步,最好使用ArrayList,事实上ArrayList的存在基本上就是为了淘汰Vector,因为大多数情况下我们只是需要一个动态存储器,而不涉及同步问题。

    另外,使用ArrayList,又想保证线程安全性,可以这么做:

List<Integer> list=Collections.synchronizedList(new ArrayList<Integer>());

   其内部基于参数ArrayList的实例,在方法外面加了一层synchronized同步,返回了一个新建的List,这个新的list对很大多数方法实现了同步。想了解更多可以看一下源码。

你可能感兴趣的:(vector,同步,ArrayList)