区别:
(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对很大多数方法实现了同步。想了解更多可以看一下源码。