向HashSet插入自定义对象判断是否重复

一.HashSet概述

HashSet实现Set接口,由哈希表(实际上是一个HashMap实例)支持。它不保证set 的迭代顺序;特别是它不保证该顺序恒久不变。此类允许使用null元素。

二.存储方式与实现

如果不等,则添加到该数组索引对应的链表中。

Set的实现类的集合对象中不能够有重复元素,HashSet也一样他是使用了一种标识来确定元素的不重复,HashSet用一种算法来保证HashSet中的元素是不重复的,HashSet采用哈希算法,底层用数组存储数据。默认初始化容量16,加载因子0.75

Object类中的hashCode()的方法是所有子类都会继承这个方法,这个方法会用Hash算法算出一个Hash(哈希)码值返回,HashSet会用Hash码值去和数组长度取模, 模(这个模就是对象要存放在数组中的位置)相同时才会判断数组中的元素和要加入的对象的内容是否相同,如果不同才会添加进去。

三.Hashset在判断是否重复机制

当调用了 HashSet 的 add 方法存放对象 obj , HashSet 会首先调用 obj 的 hasCode 方法得到该对象的哈希码, HashSet 会使用一个算法把它的哈希码转换成一个数组下标,该下标“标记”了 obj 的位置。如果这个位置上的链表中没有元素,那么就把 obj 对象添加到链表上。如果这个位置上的链表中已经有了元素,则遍历这个链表,调用 obj 的 equals 方法,判断 obj 是否和其中的某个元素重复,如果没有重复的元素,那么就将 obj 添加到链表上;如果有重复的元素,则不会将 obj 对象存入 HashSet 中。


四.自定义对象重复判断

所以,如果自定义类的插入查重,就要重写equals方法,在这同时,我们还的先重写hashCode方法,不然的话,HashSet插入的时候首先判断的是所生成的hashcode是否相同,如果相同的话,才会调用之前重写的equals方法。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: HashSet集合去除重复的原理是利用了HashMap的key的唯一性,将集合中的元素作为key加入HashMap中,由于key唯一,所以重复元素只会存储一次。要去除内容一样的对象,需要自定义该类的hashCode()和equals()方法,以保证元素作为key时可以比较内容是否相同。 ### 回答2: HashSet集合去除重复的原理是根据对象的hashCode()和equals()方法。当向HashSet集合中添加元素时,首先会调用元素的hashCode()方法计算哈希码,然后根据哈希码找到对应的存储位置,如果该位置为空,则直接存储元素。如果该位置已经有元素存在,会调用该元素的equals()方法与新元素进行比较,如果equals()方法返回true,表示两个元素相等,则不存储重复的元素,如果equals()方法返回false,则存储该元素。 要去除内容一样的对象,需要保证这些对象重写了equals()和hashCode()方法。equals()方法用于比较两个对象的内容是否相同,而hashCode()方法用于计算对象的哈希码。当两个对象内容相同时,它们的hashCode()方法返回的哈希码也必须相同。这样才能保证HashSet集合根据哈希码找到相同存储位置并调用equals()进行比较,从而去除重复对象。 为了去除内容一样的对象,我们可以按照以下步骤进行操作: 1. 在对象的类中重写equals()方法,比较对象的内容是否相同。 2. 在对象的类中重写hashCode()方法,保证内容相同的对象返回相同的哈希码。 3. 创建一个HashSet集合。 4. 将需要去重的对象依次添加到HashSet集合中。 5. HashSet集合会自动根据对象的hashCode()和equals()方法去除重复的元素。 这样就能够去除内容一样的对象,保证HashSet集合中只保留一个对象,从而实现去重功能。 ### 回答3: HashSet集合的去除重复原理是通过其内部的哈希表实现的。当我们向HashSet插入元素时,HashSet会调用每个元素的hashCode()方法得到一个哈希值,然后根据这个哈希值将元素放到不同的位置上。当插入的元素与集合中已有的元素发生哈希冲突时(即哈希值相同),HashSet会调用元素的equals()方法来比较它们的内容是否相同。 如果两个元素的哈希值相同且内容也相同(equals()返回true),HashSet会认为它们是重复的,不会将其插入集合中。这样,在HashSet中就不会出现重复的元素了。 要去除内容相同的对象,我们可以重写对象的hashCode()和equals()方法。在重写这两个方法时,我们需要保证当两个对象的内容相同时,它们的哈希值也相同(hashCode()相同),并且equals()方法返回true。这样,HashSet集合在插入元素时就会自动判断对象的内容是否相同,从而避免重复插入。 具体来说,我们需要在hashCode()方法里计算对象内容的哈希值,并在equals()方法里判断对象内容是否相同。如果两个对象的内容相同,则它们的hashCode()返回的值也应相同,并且equals()返回true。这样,HashSet集合就可以正确地去除内容相同的对象
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值