有序VS无序(Java基础语法)

前言:Set相当于集合(唯一),Map相当于映射(键对值)

一、 无序 (Unordered)
  • 核心定义: 元素的排列顺序与添加顺序元素大小都无关,不可预测,不可依赖,就好比薛定的的猫一样,你把1,2,3放进去之后,它可能会把顺序打乱,也可能不会,你不输出出来,你也不知道他是怎么排序的。

  • 代表: HashSet, HashMap

  • 关键优势: 性能最高效。


Plaintext 模拟:
输入顺序: add(20), add(10), add(30)

复制代码
// HashSet 最终状态 (一种可能的混乱结果):
[10, 30, 20]

二、 有序 (Ordered)

分为以下两种完全不同的"有序":

  • 核心定义: 严格保持元素被添加时的先后顺序,忠实记录操作历史。

  • 代表: LinkedHashSet, LinkedHashMap, 所有 List (如 ArrayList)

  • 关键优势: 需要去重但又不能打乱原始序列。


Plaintext 模拟:
输入顺序: add(20), add(10), add(30)

复制代码
// LinkedHashSet 最终状态 (严格等于输入顺序):
[20, 10, 30]

  • 核心定义: 集合自动 根据元素自身的大小指定规则进行排序。

  • 代表: TreeSet, TreeMap

  • 关键优势: 集合始终保持有序状态,便于查找和范围操作。


Plaintext 模拟:
输入顺序: add(20), add(10), add(30)

复制代码
// TreeSet 最终状态 (按数字从小到大自动排序):
[10, 20, 30]
相关推荐
月明长歌2 分钟前
【码道初阶】Leetcode面试题02.04:分割链表[中等难度]
java·数据结构·算法·leetcode·链表
silence2504 分钟前
Maven Central 上传(发布)JAR 包流程
java·maven·jar
qq_381454996 分钟前
数据脱敏全流程解析
java·网络·数据库
郝学胜-神的一滴8 分钟前
设计模式依赖于多态特性
java·开发语言·c++·python·程序人生·设计模式·软件工程
测试人社区—小叶子12 分钟前
DevTestOps成熟度模型:从CI/CD到质量门禁
java·运维·网络·人工智能·测试工具·ci/cd·自动化
honder试试18 分钟前
客户端连接Clickhouse连不上解决方案
java·clickhouse
lang2015092819 分钟前
深入解析Sentinel熔断机制
java·前端·sentinel
全粘架构师23 分钟前
五分钟精通RuntimeException
java·exception
故渊ZY23 分钟前
JVM栈帧深度解析:规范与实战
java·栈帧
流绪染梦24 分钟前
多表联查时处理一对多的信息,将子表字段放入数组
java·数据库