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返回对象集合,编译器是无法查错得,只有在运行时才能才能发现。
博客主要对比了ArrayList和Vector。ArrayList方法无同步,多线程中不安全,结果不可预料,可通过Collections方法同步;其toArray返回相同对象,clone是浅拷贝,可调用ensureCapacity提高效率。Vector方法同步,线程安全,但性能不如ArrayList,且扩容机制不同,ArrayList还可由编译器检查。
227

被折叠的 条评论
为什么被折叠?



