Java 集合框架之 Set 接口

一、Set 接口基础

(一)特点

  • 用于存放任意 `Object` 对象。

  • 无序:元素存储顺序与添加顺序无关。

  • 无下标:不能通过索引访问元素。

  • 元素不能重复:判断重复基于元素内容(而非地址),如两个内容相同的 `String` 对象会被视为重复元素。

(二)方法

仅继承自 `Collection` 父接口的所有方法,无独有方法。

(三)实现类

最常用的实现类是 `HashSet`,此外还有 `LinkedHashSet`、`TreeSet` 等。

二、HashSet 详解

(一)元素去重原理

当向 `HashSet` 中添加自定义类型对象时,需通过以下两个方法保证元素内容不重复:

  1. 覆盖 `hashCode()` 方法
  • 原则:内容相同的对象需返回相同哈希码;为提高效率,内容不同的对象尽量返回不同哈希码。
  1. 覆盖 `equals()` 方法
  • 原则:内容相同的对象返回 `true`,此时该对象不会被插入到 `Set` 集合中。

(二)存储机制(底层数组 + 哈希运算)

  1. 获取存储下标:`对象哈希码值 % 底层数组长度`。

  2. 哈希码值:由对象内存地址转化而来(默认情况)。

  3. 存储逻辑:

  • 若存储位置为空,直接存入对象。

  • 若存储位置已有元素,调用 `equals()` 方法判断内容是否相同:

  • 若 `equals()` 返回 `true`(内容相同),拒绝添加。

  • 若 `equals()` 返回 `false`(内容不同),则添加元素。

(三)代码示例

java

HashSet<String> set = new HashSet<String>();

String s1 = new String("Tom");

String s2 = new String("Liucy");

String s3 = new String("Huxz");

String s4 = new String("Jerry");

String s5 = new String("Jerry");

set.add(s1);

set.add(s2);

set.add(s3);

boolean bn1 = set.add(s4);

System.out.println("s4的插入结果:" + bn1); // 输出 true

boolean bn2 = set.add(s5);

System.out.println("s5的插入结果:" + bn2); // 输出 false

三、Set 集合遍历

支持 forEach 遍历,语法与 `List` 一致:

java

Set<String> set = new HashSet<String>();

set.add("lili");

set.add("hamei");

set.add("tom");

// forEach 遍历

for (String s : set) {

System.out.println(s);

}

// 自遍历(利用 forEach 方法)

set.forEach((s) -> {

System.out.println(s);

});

四、Set 其他实现类

(一)LinkedHashSet

  • 是 `HashSet` 的子类。

  • 特点:按元素添加顺序存储。

  • 去重要求:与 `HashSet` 相同,需覆盖 `hashCode()` 和 `equals()` 方法。

  • 遍历方式:支持 forEach 遍历、自遍历。

(二)TreeSet

  • 是 `SortedSet` 接口的实现类(`SortedSet` 是 `Set` 的子接口)。

  • 特点:可对集合元素自动排序(需元素实现 `Comparable` 接口或自定义比较器)。

  • 遍历方式:支持 forEach 遍历、自遍历。

相关推荐
_F_y13 分钟前
C++重点知识总结
java·jvm·c++
打工的小王14 分钟前
Spring Boot(三)Spring Boot整合SpringMVC
java·spring boot·后端
毕设源码-赖学姐16 分钟前
【开题答辩全过程】以 高校体育场馆管理系统为例,包含答辩的问题和答案
java·spring boot
我真会写代码17 分钟前
SSM(指南一)---Maven项目管理从入门到精通|高质量实操指南
java·spring·tomcat·maven·ssm
vx_Biye_Design18 分钟前
【关注可免费领取源码】房屋出租系统的设计与实现--毕设附源码40805
java·spring boot·spring·spring cloud·servlet·eclipse·课程设计
DN金猿23 分钟前
接口路径正确,请求接口却提示404
java·tomcat
Maynor9961 小时前
OpenClaw 玩家必备:用 AI 自动追踪社区最新动态
java·服务器·人工智能
堕2741 小时前
java数据结构当中的《排序》(一 )
java·数据结构·排序算法
亓才孓1 小时前
[Class的应用]获取类的信息
java·开发语言
开开心心就好2 小时前
AI人声伴奏分离工具,离线提取伴奏K歌用
java·linux·开发语言·网络·人工智能·电脑·blender