【java面试题】如何确保HashMap中的键的唯一性

在HashMap中,确保键的唯一性是通过以下两个步骤实现的:

  1. 通过计算键的哈希值来确定插入位置,保证插入的键值对位于不同的桶中。
  2. 在同一个桶中,如果存在多个键值对,需要通过比较键的equals()方法来判断键是否相同。

下面是通过源码分析,并给出示例代码实现HashMap中键的唯一性。

首先,HashMap是基于哈希表实现的,可以通过查看HashMap的put()方法来分析实现细节。

public V put(K key, V value) {
    // 1. 计算键的哈希值
    int hash = hash(key.hashCode());

    // 2. 计算键对应的桶的索引
    int index = indexFor(hash, table.length);

    // 3. 在对应桶中查找键是否已存在
    for (Entry<K,V> e = table[index]; e != null; e = e.next) {
        Object k;
        if (e.hash == hash && ((k = e.key) == key || key.equals(k))) {
            // 键已存在,更新值
            V oldValue = e.value;
            e.value = value;
            e.recordAccess(this);
            return oldValue;
        }
    }

    // 4. 键不存在,将键值对插入桶中
    addEntry(hash, key, value, index);
    return null;
}

目录

在这里插入图片描述
欢迎关注微信公众号:数据科学与艺术 作者WX:superhe199

ashMap在插入键值对时,会先计算键的哈希值,然后再根据哈希值找到对应的桶,最后在桶中查找键是否已存在。如果存在多个键值对,则通过equals()方法比较键是否相同。

根据上述分析,可以写出以下示例代码实现HashMap中键的唯一性:

import java.util.HashMap;

public class UniqueKeyHashMap<K, V> extends HashMap<K, V> {

    @Override
    public V put(K key, V value) {
        // 在插入键值对之前,先检查键是否已存在
        if (containsKey(key)) {
            throw new IllegalArgumentException("Duplicate key: " + key);
        }
        return super.put(key, value);
    }

    public static void main(String[] args) {
        UniqueKeyHashMap<Integer, String> map = new UniqueKeyHashMap<>();
        map.put(1, "one");
        map.put(2, "two");
        map.put(3, "three");
        map.put(1, "another one"); // 抛出异常,键1已存在
    }
}

在上述示例代码中,自定义了一个UniqueKeyHashMap继承自HashMap,并重写了put()方法,先检查键是否已存在,如果存在则抛出异常。使用这个重写的HashMap类,可以确保存储的键的唯一性。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

贺公子之数据科学与艺术

你的鼓励是我最大的动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值