Collection的子接口:Set接口

  • Collection接口:单列集合,用来存储一个一个的接口
    • List接口:存储有序的、可重复的数据  --->动态数组
      • ArrayList:
      • Linkedlist:
      • Vector:
    • Set接口:存储无序的、不可重复的数据 ---->高中讲的"集合"
      • HashSet:
        • LinkedHashSet:
      • TreeSet:
  • Map接口:双列集合,用来存储一对(key - value)一对的数据  --->高中函数:y=f(x)
    • HashMap: 
      • LinkedHashMap:
    • TreeMap:
    • Hashtable:
      • Properties:

Set接口的框架:

set接口:存储无序的、不可重复的数据

一、Set的无序性和不重复性如何表现?:

1、无序性:不等于随机性。储存数据在底层数组中并非按照数组所以的顺序添加,而是根据数据的哈希值来添加。

2、不可重复性:保证添加的元素按照equals()判断时,不能返回true。即:相同的元素只能添加一个。

二、添加元素的过程,以HashSet为例:

  我们向HashSet中添加元素a,首先调用元素a所在类的hashCode方法,计算元素a的哈希值,此哈希值接着通过某种算法计算出在HashSet底层数组中的存放位置(即为:索引位置),判断数组上是否已经有元素:

  情况一:如果此位置上没有其他元素,则元素a添加成功。

  情况二:如果此位置上有其他元素b(或以链表形式存在的多个元素),则比较元素a与元素b的hash值:如果hash值不同,则元素a添加成功

  情况三:如果hash值相同,则需要调用元素a所在类的equals()方法:

      equa ls()返回true,元素a添加失败

      equals()返回false,则元素a添加成功。

  对于添加成功的情况二和情况三而言:元素a与已经存在指定索引位置上数据以链表的方式存储。

  jdk 7:元素a放到数组中,指向原来的元素。

  jdk 8:原来的元素在数组中,指向元素a。

HashSet底层:数组加链表的结构。

要求:向Set中添加到数据,其所在的类一定要重写hashCode()和equals()

要求:重写的hashCode()和equals()尽可能保持一致性:相等的对象必须具有相等的散列码

Set接口中没有额外的方法,使用的都是Collection中声明过的方法

 三、LinkedHashSet的使用

LinkedHashSet作为HashSet的子类,在添加数据的同时,每个数据还维护了两个引用,记录此数据前一个和后一个添加的数据

优点:对于频繁的遍历操作,LinkedHashSet效率高于HashSet

四、TreeSet的使用

1、向TreeSet中添加的数据,要求是相同类的对象

2、两种排序方式:自然排序(实现Comparable接口)和定制排序(Comparator)

3、自然排序中,比较两个对象是否相同的标准为:compareTo()返回的是不是0,不再是equals()。  

4、定制排序中,比较两个对象是否相同的标准为:comparator()返回的是不是0,不再是equals()。  

posted @   羽十六  阅读(36)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 25岁的心里话
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
点击右上角即可分享
微信分享提示