ArrayList:
1.ArrayList 的方法都没有同步,所以在多线程中是不安全的,必须自己同步,而且 ArrayList 很多方法声明对于多线程操作 都没有规定,就是说结果不可预料。
如何同步ArrayList和HashMap可以用
Collections.synchronizedList
List list = Collections.synchronizedList(new ArrayList(...));
Collections.synchronizedMap
2.toArray() 方法返回的是和原列表相同的对象,也就是说 :
arrayList.toArray()[0]==arrayList.get(0) 返回的是 true( 假定 arrayList 不空 ) 。
3.clone() 方法是一个浅拷贝。
4. 可以通过自己调用 ensureCapacity() 提高效率。
Vector的方法都是同步的(Synchronized),是线程安全的(thread-safe),而ArrayList的方法不是,由于线程的同步必然要影响性能,因此,ArrayList的性能比Vector好。
当Vector或ArrayList中的元素超过它的初始大小时,Vector会将它的容量翻倍,而
ArrayList只增加50%的大小,这样,ArrayList就有利于节约内存空间。
同为对象集合,ArrayList可由编译器检查而Vector则不会,所以如果用Vector返回对象集合,编译器是无法查错得,只有在运行时才能才能发现。
1.ArrayList 的方法都没有同步,所以在多线程中是不安全的,必须自己同步,而且 ArrayList 很多方法声明对于多线程操作 都没有规定,就是说结果不可预料。
如何同步ArrayList和HashMap可以用
Collections.synchronizedList
List list = Collections.synchronizedList(new ArrayList(...));
Collections.synchronizedMap
2.toArray() 方法返回的是和原列表相同的对象,也就是说 :
arrayList.toArray()[0]==arrayList.get(0) 返回的是 true( 假定 arrayList 不空 ) 。
3.clone() 方法是一个浅拷贝。
4. 可以通过自己调用 ensureCapacity() 提高效率。
Vector的方法都是同步的(Synchronized),是线程安全的(thread-safe),而ArrayList的方法不是,由于线程的同步必然要影响性能,因此,ArrayList的性能比Vector好。
当Vector或ArrayList中的元素超过它的初始大小时,Vector会将它的容量翻倍,而
ArrayList只增加50%的大小,这样,ArrayList就有利于节约内存空间。
同为对象集合,ArrayList可由编译器检查而Vector则不会,所以如果用Vector返回对象集合,编译器是无法查错得,只有在运行时才能才能发现。