Collection的子接口:Set接口
- Collection接口:单列集合,用来存储一个一个的接口
- List接口:存储有序的、可重复的数据 --->动态数组
- ArrayList:
- Linkedlist:
- Vector:
- Set接口:存储无序的、不可重复的数据 ---->高中讲的"集合"
- HashSet:
- LinkedHashSet:
- TreeSet:
- HashSet:
- List接口:存储有序的、可重复的数据 --->动态数组
- 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()。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 25岁的心里话
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器