Hashset

Java中有两类集合(Collection),一类是List,一类是Set,前者是有序的,元素可以重复,后者是无序的,元素不可以重复


HashCode的用途:
那么在set类型的集合中,如何判断元素是否重复呢,这就需要使用Object.equals方法,但如果元素很多了,添加一个新元素时,比较的次数

就很多,例如已经有100个元素了,添加第101个元素时,就要和前面的元素比较100次,效率很低。


JAVA中采用哈希表的原理,哈希是个人名,它提出了哈希算法的概念,哈希算法也称为散列算法,是将数据依据酸法直接指定到一个地址上,

hascode实际上是返回的对象存储的物理地址

当存储一个新元素时,先调用元素的hascode的方法,就一下指定到了它应该存放的物理地址上,如果这个地址上没有元素,就直接存储了,如

果有元素,会调用equals方法进行比较,如果相等的就不存了,不相等的话就保存到另外一个物理地址上

 

1、继承set接口,不允许有重复的元素。

  

 

运行结果:

set1 size:::::2

set1 size:::::AA

set1 size:::::ABC

 

2 如果两个实例的Hashcode 和equals返回的值都相同,hashcode会认为两个实例是同一个对象,只存放前一个实例(无论两个实例是否是同一个类的实例)。

 

 

运行结果:

--------the same Class Instance with the same hashCode,equals return true----------

true

HashSet length:::::1

--------Different Class Instance with the same hashCode,equals return true----------

HashSet length:::::1

 

有一点必须注意:

如果equals返回true,必须保证hashCode必须相同。hashCode相同,equals不一定相同。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值