Java hashCode 不能与 HashMap 一起使用吗?

vox*_*elv 1 java grid hashmap hashcode sparse-matrix

我正在尝试使用 HashMap 实现稀疏网格,但是似乎重写 hashCode() 并没有按照我的预期工作。我将问题归结为以下代码:

public class Main {

private static class Coord {
    int x, y;

    public Coord(int x, int y) {
        this.x = x;
        this.y = y;
        }

        @Override
        public int hashCode() {
            // See https://en.wikipedia.org/wiki/Pairing_function#Cantor_pairing_function
            return (((x + y) * (x + y + 1)) / 2) + y;
        }
    }

    public static void main(String[] args) {
        HashMap<Coord, String> grid = new HashMap<Coord, String>();
        grid.put(new Coord(0, 0), "A");
        System.out.println(grid.get(new Coord(0, 0)));
    }
}
Run Code Online (Sandbox Code Playgroud)

我期望输出是:

A
Run Code Online (Sandbox Code Playgroud)

但是,输出是:

null
Run Code Online (Sandbox Code Playgroud)

两个“new Coord(0, 0)”实例应该返回相同的 hashCode(),但它似乎没有按我的预期工作。为什么它没有按照我的预期工作?

Joe*_*e C 5

AHashMap不能单独工作hashCodeequals它也依赖于。

为了解释原因,让我们考虑一个HashMap<String, ?>. 假设有一秒钟,一个人有无限的内存,可以为这个映射创建无限数量的键,但只有 430 万左右可能的哈希码(可能的ints 的数量)。这样,就会产生碰撞。这就是为什么equals需要这样做才能确保我们获得正确密钥的值。