Java集合-ArrayList与Vector的区别

Java集合-ArrayList与Vector的区别

1、ArrayList与Vector的底层代码

首先先看ArrayList的底层代码。如图所示:

1.实现了List接口,可以存放空元素、重复元素,元素之间存放的顺序是有序的。

2.实现了RandomAccess接口,RandomAccess接口的作用是用来标记,可以快速随机访问。

3.实现了Serializable接口,支持序列化,可以通过序列化传输。

4.实行了Cloneable接口,能被克隆。

Vector的实现接口与ArrayList一致。如图所示:

2、ArrayList与Vector的相同点

1.都是动态数组,可以自动扩容。

2.可以存放null和重复元素,存放的元素是有序的。

3.能够快速随机访问对象。

4.都能被克隆

5.支持序列化,可以通过序列化进行传输。

3、ArrayList与Vector的不相同点
1.Vector方法都是同步的,所以是线程安全的,ArrayList则不是。线程同步会影响性能,所以ArrayList性能要比Vector好。

2.ArrayList或Vector的元素超过他的默认初始容量,ArrayList会扩容50%,而Vector会翻倍。这样ArrayList会更省内存。

总结:

如果在开发中涉及到线程安全可以用Vector,其他情况都用ArrayList。




评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值