有序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]
相关推荐
松仔log21 分钟前
JetPack——Paging3+Room
android·java·zoom
Lei活在当下6 小时前
先用起来,再理解,关于协程Coroutine应该知道的事
android·java·jvm
Java爱好狂.6 小时前
Java程序员体系化学习路线(2026最新版)
java·后端·java面试·java架构师·java程序员·java八股文·java学习路线
tongluowan0076 小时前
以ReentrantLock为例解释AQS的工作流程
java·模板方法模式·aqs·reentrantlock
身如柳絮随风扬7 小时前
Java 项目打包与部署完全指南:JAR vs WAR,从构建到运行
java·firefox·jar
云烟成雨TD8 小时前
Spring AI Alibaba 1.x 系列【62】时光旅行(Time-Travel)
java·人工智能·spring
浩少7028 小时前
【无标题】
java·开发语言
一棵白菜8 小时前
java 学习
java
卷毛的技术笔记8 小时前
Java后端硬核实战:用Spring AI Alibaba+Redis给LLM装上“超强记忆中枢”
java·人工智能·redis·后端·spring·ai·系统架构
AKA__Zas10 小时前
初识多线程(3.0)
java·开发语言·学习方法