黑马程序员技术交流社区

标题: ArrayList和Vevtor的区别以及各种集合的使用条件 [打印本页]

作者: MayDay-    时间: 2016-7-28 21:37
标题: ArrayList和Vevtor的区别以及各种集合的使用条件
ArrayList和Vector都是java的集合类,都可以用来存放java对象,这是他们的相同点。
区别是:
1.同步性:
   Vector是同步的。这个类中的一些方法保证了Vector的对象是线程安全的,而ArrayList则是异步的,因此ArrayList中的对象并不是线程安全的。因为同步的要求会影响执行效率,所以以,如果你不需要先撤咯安全的集合,那么选择ArrayList是一个很好的选择,这样可以避免由于同步带来的不必要的性能开销。
2.数据增长
  从内部的实现机制来讲,ArrayList和Vertor都是使用数组来控制集合中的对象,当你向这两种类型中增加元素的时候,如果元素的数目超出了内部的数组目前的长度,它们都是需要扩展数组的长度,Vector缺省情况下自动增长原来一倍的数组长度,ArrayList是原来的50%,所以最后你获得的这个集合所占的空间总是比你实际需要的大。所以你要在集合中保存大量的数据,那么使用Vector有一些优势,因为你可以通过设置集合的初始化大小来避免不必要的资源开销。
如果要求线程安全:使用Vector.Hashtable
如果不要求线程安全:使用ArrayList.HashMap.LinkedList
如果数据量大又要线程安全考虑:Vector
作者: Kaweh.    时间: 2016-7-28 23:46
总结的很好
作者: wwwjaycn0717    时间: 2016-7-29 01:35
总结的不错




欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/) 黑马程序员IT技术论坛 X3.2