您无法以这种方式这样做。都
t和
a将有不同的
hashCode()值,因为该
java.lang.Array.hashCode()方法是从继承
Object,它使用参考来计算哈希码(默认实现)。因此,对于阵列的哈希码是参照相关的,这意味着你会得到不同的散列码值
t和
a。此外,
equals由于这也是基于引用的,因此不适用于两个数组。
您执行此操作的唯一方法是创建一个自定义类,该类将
boolean数组保留为内部成员。然后,您需要重写
equals并
hashCode以确保包含具有相同值的数组的实例相等并且具有相同的哈希码的方式重写。
一个更简单的选择可能是
List<Boolean>用作密钥。根据文档,
hashCode()实现的
List定义为:
int hashCode = 1;Iterator<E> i = list.iterator();while (i.hasNext()) { E obj = i.next(); hashCode = 31*hashCode + (obj==null ? 0 : obj.hashCode());}如您所见,它取决于列表中的值而不是引用,因此这对您来说应该有效。



