Set集合不重复原理

一、什么是Set集合?

        Set集合是Collection集合的子接口,是一个无序不重复元素的集。

二、Set集合的作用

         Set集合有三个常用子类:①HashSet,底层是HashMap,添加原理是哈希表,特点:无序(新增顺序和获取顺序不一定一致), 哈希表:数组+链表+红黑树。数组是Node类型的,它的长度是16,当元素占满"数组"的0.75(加载因子)或者当数组的同一个索引值下挂的数据大于八个并且数组的长度小于64时便会扩容,扩容规则为:newCap = oldCap << 1,即:新容量等于就容量乘以2。扩容的目的是为了查找元素效率高。  红黑树: 当同一个索引值下挂的数据大于八个并且数组长度大于等于64,就会把该索引值位置下链表结构转换为红黑树。

 class Node<K,V>{//这个结构就是一个单项链表的结构
 *       int hash;
 *       K key
 *       Node<K,V> next;
 *}

②LinkedHashSet,哈希表+链表。有序;③TreeSet,红黑树,可排序的;TreeSet的泛型必须是Comparable类型的。

三、Set集合新增原理

        先通过hashCode()方法(该方法属于Object类的方法)求新增数据的哈希值,再将新增数据的哈希值%数组长度,得到余数,即为新增数据在数组中的索引值位置,此时如果该位置为null:则直接新增到该位置,如果不为null:则判断两个元素的哈希值&& (地址值||equals),如果哈希值和地址值或者哈希值与equals有一个条件满足,就认为是同一个元素,就不会新增,如果哈希值和地址值或者哈希值与equals两个条件都不满足,则新增挂到链表的最后位置。

// 判断两个元素是否相同的逻辑:
     p.hash == hash && ((k = p.key) == key || (key != null && key.equals(k)))

        hashCode方法得到的哈希值简单来说可以理解为地址值。

效果如图所示:

​​​​​​​

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值