在Java中,equals和hashCode是一对重要的方法,通常需要同时重写它们。这是因为equals方法用于判断两个对象是否相等,而hashCode方法用于计算对象的哈希值。在使用集合类(如HashSet、HashMap等)时,它们内部会用到hashCode方法来快速定位元素,然后再用equals方法来比较元素是否相等。
如果你只重写了equals方法而没有重写hashCode方法,那么当对象被放入HashSet、HashMap等集合中时,由于没有重写hashCode方法,它将使用默认的hashCode实现。这将导致两个逻辑上相等的对象计算出的哈希值不同,从而导致集合类无法正确地操作这些对象。这样就会出现一些非常奇怪的问题,例如当你在HashSet中添加两个逻辑上相等的对象时,HashSet中会出现两个元素。
因此,为了保证集合类能够正常运作,必须重写hashCode方法,以保证逻辑上相等的对象计算出的哈希值相同。另外,根据Java规范的规定,如果两个对象相等,那么它们的哈希值必须相等,这是为了保证hashCode方法的正确性和一致性。