hashset类为什么不能添加重复的元素,在set在添加的时候先比较hashcode的值,在比较equals的值

本文探讨了在Java中HashSet集合如何通过hashCode和equals方法判断元素的唯一性。通过对Person类实例的分析,解释了重写这两个方法的重要性,以确保集合正确识别重复元素。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

package cn.itcast.day07;

import java.util.HashSet;

这是没有重写person类中的hashcode方法,和equals方法
public class SetDemo1 {
public static void main(String[] args) {

    //hashset中是不允许出现两个重复的元素,set在添加的时候,会先比较两个对象的hashcode是不是相等
    //如果两个对象的hashcode相等的情况下,在通过比较两个的equals的方法
    //其中的hashcode的比较在object是通过在系统中随机生成一个十进制的数
    HashSet<Person> set = new HashSet<>();
    Person p1 = new Person("小美女",22);
    Person p2 = new Person("小美女", 22);
    Person p3 = new Person("我的小南",23);

    set.add(p1);
    set.add(p2);
    set.add(p3);

    System.out.println(set);  //三个元素都被添加了
    //==是计较两个对象的地址
    System.out.println(p1 ==p2);//false
    //表示查询两个对象的字符串是不是相等
    System.out.println(p1.equals(p2));//false

    System.out.println(p1.hashCode());//两个比较的是不同的
    System.out.println(p2.hashCode());

}

}

这是重写了hashcode和equals的方法后的结果 添加了两个元素,并且hashcode的值是相等的
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值