ArrayList与Vector的区别

本文详细对比了Vector与ArrayList在产生版本、线程安全、初始化及扩容策略等方面的差异。Vector自JDK1.0时代便存在,通过方法级加锁确保线程安全,但效率较低。ArrayList则自JDK1.2引入,采用异步处理提高性能,但牺牲了线程安全性。Vector默认初始化容量为10,扩容时翻倍;而ArrayList采用懒加载,初始容量动态,扩容为1.5倍。
摘要由CSDN通过智能技术生成
  1. 产生版本:
    Vector是JDK1.0产生的,ArrayList是JDK1.2产生的
  2. 线程安全:
    Vector采用在方法上添加synchronized来保证线程安全,性能较低;
    ArrayList采用异步处理,性能较高,不安全。
  3. 初始化以及扩容策略:
    Vector对象产生时就初始化数组大小为10,当数组不够用时,扩容为源数组2倍;
    ArrayList使用懒加载策略,在第一次添加元素时才初始化数组大小,当数组不够用时,扩容为源数组的1.5倍。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值