英文原文:
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代码。
本文讨论了在Java中Vector与ArrayList的选择问题,详细分析了同步性、数据增长方式、使用模式及性能表现。对于追求高效并发操作的应用场景推荐使用Vector;而对于更注重性能且不需要线程安全的场景,则推荐使用ArrayList。
3348

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



