[Essential] - Hashtable 与 Hashmap 的区别

本文对比了HashTable与HashMap在Java中的主要区别,包括同步机制、null值处理、哈希值使用方式等,并介绍了ConcurrentHashMap作为替代方案的优势。

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

1.HashTable的方法是同步的,HashMap未经同步,所以在多线程场合要手动同步HashMap这个区别就像Vector和ArrayList一样。
[如何手功同步?]
关于详细的手功同步参看文章: http://www.diybl.com/course/3_program/java/javajs/2008515/116888.html

这里是结论:
1、如果 ConcurrentHashMap 够用,则使用 ConcurrentHashMap。
2、如果需自己实现同步,则使用 JDK1.5 提供的锁机制,避免使用 synchronized 关键字。

[JAVA同步的机制]

2.HashTable不允许null值(key和value都不可以),HashMap允许null值(key和value都可以)。

3.HashTable有一个contains(Object value),功能和containsValue(Object value)功能一样。

4.HashTable使用Enumeration,HashMap使用Iterator。
[Enumeration]与[Iterator]的区别?
暂时只找到这一段:
Iterator和enumeration都是用来访问集合的接口.
在Iterator接口中定义了三个方法
1.hasNext() 是否还有下一个元素
2.next() 返回下一个元素
3.remove() 删除当前元素
enumeration只定义了前2个方面,没有remove方法,不具备删除功能.

以上只是表面的不同,它们的实现也有很大的不同。

5.HashTable中hash数组默认大小是11,增加的方式是 old*2+1。HashMap中hash数组的默认大小是16,而且一定是2的指数。

6.哈希值的使用不同,HashTable直接使用对象的hashCode
[hashCode的作用]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值