成长复习2

本文详细阐述了HashMap和Hashtable的区别,包括同步性、效率和使用场景。通过实例对比展示了两者在处理键值对时的不同表现,强调了在不同需求下如何选择合适的集合类。

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

HashMap与Hashtable的区别
同步性
Hashtable是线程同步的,其中的对象是线程安全的
同步的执行影响效率
不考虑安全问题的话用HashMap
HashMap hp = new HashMap();hp.put(null,null);System.out.println("测试"+hp.get(null));这个会输出null
Hashtable ht = new Hashtable();ht.put(null,null);System.out.println("测试"+ht.get(null));这个会报错
类似Vector是同步的缺省状态增长原来的一倍长度,ArrayList是异步的,缺省状态满了之后会怎张50%

如果要求线程安全用 Vector 、 Hashtable
否则用ArrayList、LinkedList、HashMap
如果用键值对选HashMap Hashtable
如果数据量很大而且还要线程安全Vector

泛型---安全简单
java的反射机制
类型安全
向后兼容
层次清晰,性能较高,可以拿到类型信息,为优化带来方便

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值