Java8改进的HashMap和Hashtable实现类

本文详细阐述了HashMap和Hashtable的实现原理、区别以及在Java编程中的应用,特别强调了线程安全性和null值的处理。

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

HashMap和Hashtable都是Map接口的典型实现类,它们之间的关系完全类似于ArrayList和Vector的关系:Hashtable是一个古老的Map实现类,它从JDK1.0起就已经出现了,当它出现时,Java还没有提供Map接口,所以它包含了两个繁琐的方法,即elements()(类似于Map接口定义的values()方法)和keys()(类似于Map接口定义的keySet()方法),现在很少使用这两个方法(关于这两个方法的用法请参考)

        Java8改进了HashMap的实现,使用HashMap存在key冲突时依然具有较好的性能。

         除此之外,Hashtable和HashMap存在两点典型区别。

        (1)Hashtable是一个线程安全的Map实现,但HashMap是线程不安全的实现,所以HashMap比Hashtable的性能高一点;但如果有多个线程访问同一个Map对象时,使用Hashtable实现类会更好。

 (2)Hashtable不允许使用null作为key和value,如果试图把null放进Hashtable中,将会引发空指针异常;但HashMap可以使用null作为key或value。

   由于HashMap里的key不能重复,所以HashMap里最多只有一个key-value对的key为null,但可以有无数多个key-value对的value为null.

下面程序示范了用null值作为HashMap的key和value的情形。

package com.zhao.three;

import java.util.HashMap;

public class NullInHashMap {
	public static void main(String[] args) {
		HashMap   hm=new HashMap<>();
		hm.put(null, null);
		hm.put(null, null);
		hm.put("a", null);
		System.out.println(hm);
	}
}

      上面程序试图向HashMap中放入三个key-value对,其中第二行代码处无法将key-value对放入,因为Map中已经有一个key-value对的key为null值,所以无法再放入key为null值的key-value对。第三行代码处可以放入该key-value对,因为一个HashMap中可以有多个value为null值。编译、运行上面程序,看到如下输出结果;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值