英文原文:http://www.javaworld.com/javaworld/javaqa/2001-06/03-qa-0622-vector.html
采用Vector还是ArrayList,应该考虑以下4个因素:
Synchronization
Vector是Synchronized, 它的所有方法都是thread safe的。ArrayList是unsynchronized。所以,如果带抹布需考虑threadsafe, 完全可以采用ArrayList, 它的效率更高
Data growth
插入一个element到一个队列已满的vector时,Vector增长的size是原来size的一倍,而ArrayList增长0.5倍。不过,Vector可以设置增长值,这在有些情况下是有用的。
Usage patterns
Usage patterns
这两个类都适合于这种情况:从一个指定位置取element, 在array末尾增加或删除element. 如果希望从中间插入或删除element,可能需考虑linkedList。
最后,如果需要考虑性能时,最好采用自己写的简单的array代码。
博客讨论了采用Vector还是ArrayList需考虑的4个因素。包括同步性,Vector是同步的、线程安全,ArrayList非同步、效率更高;数据增长方面,Vector增长一倍,ArrayList增长0.5倍且Vector可设增长值;使用模式上,二者适合特定操作,中间插入删除可考虑linkedList,追求性能可用简单array代码。
5633

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



