HashMap和HashTable的区别

本文详细解析了Java集合类HashMap与Hashtable,以及ArrayList与Vector之间的区别,包括同步性、空值处理和数据增长策略。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

       HashMap和Hashtable的区别


HashMap与Hashtable都是java的集合类,都可以用来存放java对象,这是相同点


区别:


1.历史原因:Hashtable是基于陈旧的Dictionary类的,HashMap是java1.2引进的Map接口的一个实现。


2.同步性 hashmap是同步的,这个类中的一些方法保证了hashtable中的对象是线程安全的,二hashmap是


异步的,因此hashMap并不是线程安全的。同步的要求会影响执行的效率,所以不需要安全的集合使用


hashMap是很好的选择,这样可以避免由于同步带来的不必要的性能开销,从而提高效率。


3.值:hashMap可以让你将空值作为一个表的条目的


key或value,但是HashMap是不能放入空值的。


ArrayList和Vector的区别


1.ArrayList是异步的,Vector是同步的


2.数据增长:vector缺省情况下自动增长原来一倍数组长度,ArrayList是原来的50%。保存大量数据的时

候使用Vector有一些优势



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

蟹道人

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值