HashSet集合的不重复和存储原理

概述
  • HashSet集合里面的元素不允许重复,而且存储没有顺序
  • 没有索引,不可以使用普通for循环遍历,但可以使用正确for循环—>foreach遍历。可以使用迭代器iterator()进行迭代遍历,但要注意并发异常问题。
  • 底层是使用hash表进行存储的,哈希表是由数组+链表实现的。JDK1.8后,在存储数量少于8个,就还是原来的数组+链表。多于8个元素后,就是数组+红黑树。
存储原理
  • 首先,根据存储元素,调用其元素的hashCode()方法,获得其哈希值
  • 根据哈希值,在数组的下标为哈希值的位置上,查看是否存在元素。如果没有元素就直接存储进去
  • 如果对应位置有元素,就调用其equals()方法,比较它们的值,看是否相等,相等就不添加,不相等就添加
  • 示例代码
import java.util.*;
//类A重写了equals方法
class A
{
	public boolean equals(Object obj){
		return true;
	}
}
//类B重写了hasCode()方法
class B
{
	public int hashCode()
	{	
		return 1;
	}
}
//类C重写了equals(),hasCode()方法,让它们都返回相同的true,hasCode值
class C
{
	public int hashCode(){
		return 2;
	}
	public boolean equals(Object obj){
		return true;
	}
}
@SuppressWarnings("unchecked")
public class HashSetTest
{
	public static void main(String[] args){
		HashSet books = new HashSet();
		//往hashSet对象添加对象,
		//1.HahSet会调用该对象的hashCode()方法来得到该对象的hashCode值
		//然后根据该对象的hashCode值决定该对象在hashSet的存储位置
		//2.如果该对象的equals返回值是true,表示这两个对象相等,但hashCode不一样,一样存储
		//3.HashSet集合判断两个元素相等的标准是两个对象通过equals()方法比较相等,并且两个对象的			//hashCode()方法返回值也相等。
		//一般内置的方法,在它们true时,就处理了,令其hashCode相同,因此不能在set存储相同元素
		books.add(new A());
		books.add(new A());
		books.add(new B());
		books.add(new B());
		books.add(new C());
		books.add(new C());
		System.out.println(books);
	}
}
  • 结果
    在这里插入图片描述
  • 理解:由于A类只重写其equals()方法,虽然它返回的是true,但首先是调用其hashCode()方法,默认是返回其地址值,由于是new了两个A对象,所以其哈希值不一样,所以就添加进去
  • 理解:B类只重写了其hashCode()方法,因为返回的哈希值相等,就比较其是否相等,调用equals()方法,返回fasle,其不相等,就添加进入,虽然在同一个位置
  • 理解:C类重写了equals()和hashCode()方法,首先添加两个C对象进去时,它们的哈希值相等,再调用其equals(),其返回true,即重写的equals()认为它们相等,因此只添加了第一个。
注意
  • 如果需要把某个类的对象保存到HashSet集合中,重写这个类的equals()方法和hashCode()方法时,应该尽量保证两个对象通过equals()方法比较返回true时,它们的hashCode()方法返回值也相等。
  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 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、付费专栏及课程。

余额充值