java后端面经--hashtable和hashmap的区别

本文详细对比了hashtable和hashmap的区别,包括线程安全性、继承结构、初始化容量及扩容策略、键值对约束、遍历方式以及内部地址计算方法。hashtable是线程安全的,继承自dictionary类,而hashmap则不同步,继承自abstractmap类。在初始化时,hashtable初始容量为11,扩容为2n+1,hashmap则是16,扩容为2n。对于key和value,hashtable均不能为null,而hashmap允许。此外,hashtable使用自身的enumeration遍历,hashmap则采用iterator。在计算内部地址时,两者算法有所不同。

hashtable和hashmap区别:
外部:
1,同步,线程安全;不同步,线程不安全
2,继承不同,dictionary类,abstractmap类
内部:
1,初始化空间,扩容:hashtable 11,2n+1;hashmap 16,2n;
2,key,value:hashtable都不能为空,hashmap可以为空。
3,遍历方式:hashtable:自己的方法(Enumeration) hashmap:iterator
4,计算内部地址(idx)值不同:
hashtable,用key的hash加工后%对象的length
hashmap,用key的hash进行与运算(冲突较多)
(背诵一遍:外部:同步,父类,内部,初始化,扩容,key,valve,遍历,计算内部地址)

HashtableHashMapJava中两种常用的哈希表实现的Map接口的实现类,它们之间有以下几个区别: 1. 线程安全性:Hashtable是线程安全的,而HashMap不是。Hashtable的所有方法都是同步的,可以在多线程环境下使用,但是会影响性能。而HashMap在多线程环境下需要通过外部同步来保证线程安全。 2. 同步性:Hashtable是通过synchronized关键字实现同步的,而HashMap不是。因此,在单线程环境下,HashMap的性能比Hashtable更好。 3. 允许null键null值:Hashtable不允许键或值为null,而HashMap允许null键null值。当需要存储null值时,可以选择使用HashMap。 4. 迭代器的失败-fast-fail机制:当在迭代过程中对集合进行修改时,Hashtable会抛出ConcurrentModificationException异常,而HashMap则不会。这是因为Hashtable在迭代过程中使用了一个modCount变量来记录集合被修改的次数,而HashMap没有。 5. 初始容量扩容机制:Hashtable的初始容量为11,扩容时容量会翻倍加1;HashMap的初始容量为16,扩容时容量会翻倍。因此,HashMap的扩容次数相对较少,性能相对较好。 下是一个演示HashtableHashMap区别的例子: ```java import java.util.Hashtable; import java.util.HashMap; public class HashTableHashMapDemo { public static void main(String[] args) { // 创建HashtableHashMap对象 Hashtable<Integer, String> hashtable = new Hashtable<>(); HashMap<Integer, String> hashMap = new HashMap<>(); // 添加键值对 hashtable.put(1, "One"); hashtable.put(2, "Two"); hashtable.put(3, "Three"); hashMap.put(1, "One"); hashMap.put(2, "Two"); hashMap.put(3, "Three"); // 输出键值对 System.out.println("Hashtable: " + hashtable); System.out.println("HashMap: " + hashMap); } } ```
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值