【Java-集合】Set接口

(1 特点:存储多个任意类型的对象,无序、无下标、元素 的内容不允许重复。

(2) 方法:继承于父接口 Collection 中的方法。

(3) 实现类:HashSet

a. 自定义类型的对象存储在HashSet中,如何保证 HashSet元素内容不重复?

i. 覆盖 hashCode方法

原则:必须保证相同内容的对象返回相同的哈希码值,为了提高效率,尽可能的做到,不同内容的

对象返回不同的哈希码值

覆盖准则:通常将所有的属性拼凑为一个 int 类型的结果进行返回。

案例: public int hashCode(){

return this.name.hashCode()+this.age.hashCode(); // age 包装类型

}

ii. 覆盖 equals方法

必须保证相同内容的对象返回true -> 拒绝添加到HashSet集合中。

b. HashSet保证元素不重复执行的原理:对象往HashSet集合中存储时,当前对象调用自身hashCode方

法,获取哈希码值,从而获取对应存储下标,如果存储下标上没有存储任何元素,则当前对象直接存

储,但是如果存储下标上已经有存储了其他对象,则调用equals方法,进行比较对象的内容是否相

同,equals方法的结果为true,代表相同内容的对象,则HashSet集合拒绝添加,equals方法结果为

false,则代表内容不同的对象,则成功添加到HashSet集合中。

(4) 遍历方式:forEach(底层原理迭代器遍历)

(5) SortedSet:是 Set的子接口,无序、无下标、对元素内容进行排序。

a. 常用的实现类TreeSet

注意:如果自定类型的对象存储在TreeSet中,需要实现 java.lang.Comparable 接口,同时实现:

compareTo方法,方法中指定排序的规则。compareTo返回值结果如果为0,则TreeSet视为

相同内容的对象。(TreeSet去除重复内容的对象,利用compareTo返回值,结果为0,相同对

象)

(6) LinkedHashSet:按照添加顺序进行集合元素存储,同时元素内容不允许重复。

注意:LinkedHashSet是 HashSet的子类,所以如果自定类型的对象存储在LinkedHashSet中,

为了保证元素内容不重复,则需要对象对应的类覆盖 hashCode方法 和 equals方法(要求

和 父类HashSet一致)。

相关推荐
m0_639817151 天前
基于springboot教学资料管理系统【带源码和文档】
java·spring boot·后端
靠沿1 天前
Java数据结构初阶——LinkedList
java·开发语言·数据结构
qq_12498707531 天前
基于springboot的建筑业数据管理系统的设计与实现(源码+论文+部署+安装)
java·spring boot·后端·毕业设计
一 乐1 天前
宠物管理|宠物共享|基于Java+vue的宠物共享管理系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·springboot·宠物
a crazy day1 天前
Spring相关知识点【详细版】
java·spring·rpc
白露与泡影1 天前
MySQL中的12个良好SQL编写习惯
java·数据库·面试
foundbug9991 天前
配置Spring框架以连接SQL Server数据库
java·数据库·spring
凯酱1 天前
@JsonSerialize
java
悦悦子a啊1 天前
项目案例作业(选做):使用文件改造已有信息系统
java·开发语言·算法
lkbhua莱克瓦241 天前
Java项目——斗地主小游戏(控制台版)
java·开发语言·windows·斗地主项目