Set集合如何判断对象是否重复

在 Set 集合中,判断对象是否重复取决于该对象的 hashCode() 和 equals() 方法的实现。当将一个元素添加到 Set 集合中时,会先调用该元素的 hashCode() 方法,得到其 hash 值,然后与集合中已有的元素的 hash 值进行比较,如果 hash 值相同,再调用元素的 equals() 方法进行比较,如果 equals() 方法也返回 true,则认为该元素重复,不会被添加到集合中。

因此,如果要将一个对象添加到 Set 集合中,并且希望能够正确地判断对象是否重复,需要确保该对象的 hashCode() 和 equals() 方法的实现符合要求,即:

  1. hashCode() 方法返回的 hash 值应该是稳定的,即如果两个对象 equals() 方法返回 true,则它们的 hashCode() 方法返回值应该相等。
  2. equals() 方法应该能够正确地比较两个对象是否相等,即如果两个对象的每个属性值都相等,则 equals() 方法应该返回 true。

需要注意的是,如果一个类没有覆盖 hashCode() 和 equals() 方法,则默认会使用 Object 类中的实现,这通常不符合要求。因此,在实现一个自定义类时,一定要正确地覆盖 hashCode() 和 equals() 方法。

猜你喜欢

转载自blog.csdn.net/qq_42133976/article/details/130417277