Java 在 Map 中使用复杂数据类型作为 Key

有时候你想这么做:

Map<User, Profile> map = new HashMap<>();
// 添加一些数据
map.put(new User(1), getProfile(1));
// 取用这些数据
if (map.containsKey(new User(1)) {
    doSomething();
}

但默认情况下这是不能成功的,因为在 HashMap 的实现中,是这么处理的:

// 代码有精简,改变了对 null 值的判断逻辑,不过这不是重点
if (key != null
    && e.hash == key.hashCode()
    && (e.key == key || key.equals(e.key)) {
    return e;
}

注意,hashCode 相同,不一定 equals() 返回 true。

也就是说,我们要手动实现 equals()hashCode() 才能达到我们的目的。

class User {

    private Integer id;

    @Override
    public int hashCode() {  
        return this.id != null ? this.id : 0;  
    }  

    @Override
    public boolean equals(Object obj) {  
        return obj instanceof User && (this.id.equals(((User) obj).id));  
    }  
}

大功告成。

Think in Java 中设计 equals() 的五条原则

  1. 自反性。 即 x.equals(x) 为 true
  2. 对称性。 若 x.equals(y) 为 true,那么 y.equals(x) 为 true
  3. 传递性。 若 x.equals(y) 为 true 且 y.equals(z) 为 true,那么 x.equals(z) 也为 true
  4. 一致性。 对于 x.equals(y),只要判定信息不变,无论比较多少次结果均应相同。
  5. x != null 为 true,那么 x.equals(null) 为 false

转载于:https://my.oschina.net/tridays/blog/759023

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值