Java中HashMap和Hashtable的区别和例子

在Java中,HashMap和Hashtable都实现了Map接口,用于存储键值对(key-value pairs),但它们之间存在一些重要的区别。

线程安全性:

HashMap是非线程安全的,这意味着在多线程环境下使用它可能会导致数据不一致或其他并发问题。如果需要在多线程环境中使用,则需要额外的同步措施。

Hashtable是线程安全的,它通过内部同步来确保在并发访问时的数据一致性。然而,这也意味着它在单线程环境下的性能可能稍低于HashMap。

null值支持:

HashMap允许null键(key)和null值(value)。

Hashtable不允许null键和null值。如果试图在Hashtable中插入null键或null值,将会抛出NullPointerException。

继承关系:

HashMap继承自AbstractMap类,并实现了Map接口。

Hashtable继承自Dictionary类,并实现了Map接口。由于Hashtable是Java早期版本的一部分,它继承了Dictionary类,但现代的Java程序更倾向于使用Map接口及其实现。

性能:

由于Hashtable是线程安全的,它在某些情况下的性能可能不如HashMap。然而,这取决于具体的使用场景和并发需求。

HashMap在单线程环境下的性能通常更好,因为它没有内部同步的开销。

示例:

这里有一个简单的示例,展示了如何在HashMap和Hashtable中存储和检索键值对:

java

import java.util.HashMap;

import java.util.Hashtable;

 

public class MapExample {

    public static void main(String[] args) {

        // 使用HashMap

        HashMap<String, Integer> hashMap = new HashMap<>();

        hashMap.put("one", 1);

        hashMap.put("two", 2);

        hashMap.put(null, 0); // 允许null键

        System.out.println(hashMap.get("one")); // 输出: 1

        System.out.println(hashMap.get(null)); // 输出: 0

 

        // 使用Hashtable

        Hashtable<String, Integer> hashTable = new Hashtable<>();

        hashTable.put("one", 1);

        hashTable.put("two", 2);

        // hashTable.put(null, 0); // 这将抛出NullPointerException

        System.out.println(hashTable.get("one")); // 输出: 1

        // System.out.println(hashTable.get(null)); // 这将抛出NullPointerException

    }

}

 

请注意,在上面的示例中,尝试在Hashtable中插入null键将导致NullPointerException。而HashMap则允许这样做。

 

  • 19
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值