java基础:去重2(HashSet对象集合)

本文介绍了Java中HashSet如何实现去重,主要依赖于元素的hashCode和equals方法。当哈希值相同时,会通过equals方法进一步判断对象是否相同。在自定义类的情况下,需要重写hashCode和equals方法来指定比较规则。文章通过Person类的例子展示了如何实现对象的去重,并提供了相关代码示例。
摘要由CSDN通过智能技术生成

HashSet:底层是哈希表,线程不安全

首先要明白HashSet是如何实现去重的:
HashSet内部默认对String类型的集合进行去重,它的原理很简单
就是通过调用元素内部的
hashCode和equals方法实现去重
1、首先调用hashCode方法,比较两个的哈希值,如果哈希值不同,直接认为是两个对象,停止比较
2、如果哈希值相同,再去调用equals方法,若判断返回true,认为是同一个对象,返回false认为是不同对象
-------HashSet在add()方法内部实现了去重功能,默认调用的是字符串的hashCodeequals方法实现去重
-------所以在你添加字符串元素时,如果相同则自动去重


*  实例:使用HashSet实现对Person1类对象的去重
*  分析:要去重写Person1的hashCode和equals方法
*  自己制定比较规则:按照姓名和年龄比较

注意:1、hashSet本身不能实现排序
      2、对于自定义的类,要想按照自己制定的比较规则进行去重,必须重写H

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值