热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

不一致的哈希码和等于java

如何解决《不一致的哈希码和等于java》经验,为你挑选了1个好方法。

经过研究,我仍然无法找到解决我问题的具体方案.我有一个使用epsilon的"近似等于"方法,而我的hashCode方法使用精确值.当我比较值时,这打破了HashSet的前提条件.

@Override
public boolean equals(Object o) {
    if (o == this)
        return true;
    if (!(o instanceof EPoint)) {
        return false;
    }
    EPoint ePoint = (EPoint) o;
    return Math.abs(Math.abs(ePoint.lat) - Math.abs(lat)) 

我找不到让hasCode()与我的equals方法一致的方法.



1> Alexey Roman..:

equals甚至在你到达之前就打破了合同,hashCode因为它不是传递性的.

这也立即导致唯一一致的hashCode实现是返回一个常量,因为任何两个点都有一个(非常长的)中间点链,所以

    因此,每两个邻居都是平等的

    每两个邻国必须具有相同的hashCode,因此,

    开头和结尾必须一样hashCode.

现在,这是一个一致的实现,但显然是无用的.


推荐阅读
author-avatar
萍子WYP
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有