一、什么是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方法得到的哈希值简单来说可以理解为地址值。
效果如图所示: