ArrayList和Vector的区别
首先ArrayList和Vector都是常用的List实现类(List用于存放多个元素,能够维护元素的次序,并且允许元素的重复。),内部都是通过数组实现的。
1)线程是否安全:
Vector支持线程的同步(Vector实现了序列化),即某一时刻只有一个线程能够写Vector,避免多线程同时写而引起的不一致性,但实现同步需要很高的花费,因此,访问它比访问ArrayList慢;Arraylist是线程异步(ASynchronized)的,是不安全的。如果不考虑到线程的安全因素,一般用Arraylist效率比较高。
2)容量增长:
二者都有一个初始容量大小(10),采用线性连续存储空间;当Vector和ArrayList中的元素超过它的初始大小时,Vector会将它的容量翻倍,而ArrayList只增加原来数组的0.5倍的大小,这样ArrayList就有利于节约内存空间。
3)用途:
如果查找一个指定位置的数据,vector和arraylist使用的时间是相同的,但是插入数据要设计到数组元素移动 等内存操作,所以索引数据快插入数据慢,Vector由于使用了synchronized方法(线程安全)所以性能上比ArrayList要差,即建议用arraylist。
总结ArrayList和Vector的区别
最新推荐文章于 2023-07-17 21:02:59 发布