JavaSE核心知识点03高级特性03-01(集合框架)

🤟致敬读者

  • 🟩感谢阅读🟦笑口常开🟪生日快乐⬛早点睡觉

📘博主相关

  • 🟧博主信息🟨博客首页🟫专栏推荐🟥活动信息

文章目录

    • JavaSE核心知识点03高级特性03-01(集合框架)
    • 一、什么是集合框架(Collection Framework)?
      • 为什么需要集合框架?
    • 二、集合框架的核心结构
      • 1. **Collection 接口(单列集合)**
      • 2. **Map 接口(双列集合)**
    • 三、核心接口详解与代码示例
      • 1. **List 接口**
        • 特点:有序、可重复、可通过索引访问
      • 2. **Set 接口**
        • 特点:无序、不可重复(通过`equals()`和`hashCode()`判断)
      • 3. **Map 接口**
        • 特点:键值对存储,Key唯一
    • 四、集合框架的通用操作
      • 1. **遍历集合**
      • 2. **集合工具类 `Collections`**
    • 五、如何选择集合类?
    • 六、常见面试问题
    • 七、学习路线建议


📃文章前言

  • 🔷文章均为学习工作中整理的笔记。
  • 🔶如有错误请指正,共同学习进步。

在这里插入图片描述

JavaSE核心知识点03高级特性03-01(集合框架)

作为Java集合框架的入门学习指南,我将从基础概念、核心接口、常用实现类、使用场景到代码示例,逐步为你讲解。内容会尽量通俗易懂,配有代码示例和对比表格,帮助你快速掌握。


一、什么是集合框架(Collection Framework)?

集合框架 是Java中用于存储和操作一组对象的统一架构。它提供了一套标准化的接口和实现类,解决了数组的局限性(如固定长度、类型单一、操作复杂等)。

为什么需要集合框架?

  • 动态扩容:无需手动管理容量
  • 类型安全:通过泛型确保数据类型一致
  • 高性能操作:提供丰富的API(增删改查、排序、遍历等)
  • 统一标准:所有集合类遵循相同的接口规范

二、集合框架的核心结构

Java集合框架主要分为两大类:单列集合(Collection)双列集合(Map)

1. Collection 接口(单列集合)

  • List:有序、可重复
    • 常用实现类:ArrayList, LinkedList, Vector
  • Set:无序、不可重复
    • 常用实现类:HashSet, LinkedHashSet, TreeSet
  • Queue:队列,先进先出(FIFO)
    • 常用实现类:LinkedList, PriorityQueue

2. Map 接口(双列集合)

  • 键值对(Key-Value)存储,Key不可重复
  • 常用实现类:HashMap, LinkedHashMap, TreeMap, Hashtable

三、核心接口详解与代码示例

1. List 接口

特点:有序、可重复、可通过索引访问

常用实现类对比

实现类数据结构特点
ArrayList动态数组查询快,增删慢(需扩容或移动元素)
LinkedList双向链表增删快,查询慢(需遍历节点)
Vector同步的动态数组线程安全,性能较低(已逐渐被淘汰)

示例代码

// ArrayList示例
List<String> arrayList = new ArrayList<>();
arrayList.add("Apple");
arrayList.add("Banana");
arrayList.add(1, "Orange"); // 在索引1插入元素
System.out.println(arrayList); // [Apple, Orange, Banana]// LinkedList示例
List<Integer> linkedList = new LinkedList<>();
linkedList.add(10);
linkedList.addFirst(5); // 头部插入
linkedList.addLast(20); // 尾部插入
System.out.println(linkedList.get(1)); // 10

2. Set 接口

特点:无序、不可重复(通过equals()hashCode()判断)

常用实现类对比

实现类数据结构特点
HashSet哈希表最快查询,无顺序
LinkedHashSet哈希表+链表保留插入顺序
TreeSet红黑树自然排序或自定义排序

示例代码

// HashSet示例
Set<String> hashSet = new HashSet<>();
hashSet.add("Java");
hashSet.add("Python");
hashSet.add("Java"); // 重复元素不会被添加
System.out.println(hashSet); // 输出顺序不确定,如 [Java, Python]// TreeSet示例(自然排序)
Set<Integer> treeSet = new TreeSet<>();
treeSet.add(5);
treeSet.add(2);
treeSet.add(8);
System.out.println(treeSet); // [2, 5, 8]

3. Map 接口

特点:键值对存储,Key唯一

常用实现类对比

实现类数据结构特点
HashMap哈希表最快查询,无顺序(允许null键值)
LinkedHashMap哈希表+链表保留插入顺序或访问顺序
TreeMap红黑树按键自然排序或自定义排序
Hashtable哈希表线程安全,不允许null键值(已过时)

示例代码

// HashMap示例
Map<String, Integer> hashMap = new HashMap<>();
hashMap.put("Alice", 25);
hashMap.put("Bob", 30);
hashMap.put("Alice", 26); // 覆盖原有值
System.out.println(hashMap.get("Bob")); // 30// TreeMap示例(按键排序)
Map<String, Integer> treeMap = new TreeMap<>();
treeMap.put("Orange", 5);
treeMap.put("Apple", 3);
System.out.println(treeMap); // {Apple=3, Orange=5}

四、集合框架的通用操作

1. 遍历集合

  • for-each循环(推荐):

    List<String> list = Arrays.asList("A", "B", "C");
    for (String s : list) {System.out.println(s);
    }
    
  • 迭代器(Iterator)

    Iterator<String> it = list.iterator();
    while(it.hasNext()) {String s = it.next();if (s.equals("B")) it.remove(); // 安全删除元素
    }
    

2. 集合工具类 Collections

提供静态方法操作集合:

List<Integer> numbers = new ArrayList<>(Arrays.asList(3,1,4,2));
Collections.sort(numbers); // 排序 → [1,2,3,4]
Collections.reverse(numbers); // 反转 → [4,3,2,1]
Collections.shuffle(numbers); // 随机打乱

五、如何选择集合类?

根据需求选择最合适的集合:

场景推荐实现类
快速随机访问ArrayList
频繁插入删除LinkedList
去重且无需排序HashSet
去重且保留插入顺序LinkedHashSet
需要排序TreeSetTreeMap
键值对存储HashMap(最常用)
线程安全场景ConcurrentHashMap

六、常见面试问题

  1. ArrayList和LinkedList的区别?

    • ArrayList基于动态数组,适合随机访问;LinkedList基于链表,适合频繁增删。
  2. HashMap的工作原理?

    • 通过哈希函数计算键的哈希值,存储到对应桶(数组位置),解决哈希冲突使用链表或红黑树(JDK8+)。
  3. 如何保证集合的线程安全?

    • 使用Collections.synchronizedList()包装,或选择ConcurrentHashMapCopyOnWriteArrayList等并发集合。

七、学习路线建议

  1. 基础阶段:掌握ArrayListHashMapHashSet的常用操作
  2. 进阶阶段:理解底层数据结构(如哈希表、红黑树)、泛型、迭代器
  3. 高级阶段:学习线程安全集合、性能优化、Stream API操作集合

练习建议

  • 实现一个简单的学生管理系统(用集合存储学生信息)
  • 统计一篇文章中每个单词出现的次数(用HashMap
  • 比较不同集合在10万次操作下的性能差异

如果有具体问题或需要更多代码示例,欢迎随时提问!



📜文末寄语

  • 🟠关注我,获取更多内容。
  • 🟡技术动态、实战教程、问题解决方案等内容持续更新中。
  • 🟢《全栈知识库》技术交流和分享社区,集结全栈各领域开发者,期待你的加入。
  • 🔵​加入开发者的《专属社群》,分享交流,技术之路不再孤独,一起变强。
  • 🟣点击下方名片获取更多内容🍭🍭🍭👇

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.pswp.cn/pingmian/81935.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

日志分析-IIS日志分析

环境准备 https://xj.edisec.net/challenges/115 题目要求 windows系统中才有的IIS服务 既然是windows平台&#xff0c;当然需要rdp登录&#xff0c;在ssh登录失败 解题过程 phpstudy--2018站点日志.(.log文件)所在路径&#xff0c;提供绝对路径 Windows服务的日志一般有固定…

一、web安全基础入门

1、Windows命令 文件和目录操作 dir&#xff1a;列出当前目录下的文件和子目录。cd&#xff1a;切换目录&#xff0c;例如 cd C:\Users 切换到C盘的Users目录。md 或 mkdir&#xff1a;创建新目录&#xff0c;如 md testdir。rd 或 rmdir&#xff1a;删除空目录&#xff0c;例…

动态规划应用场景 + 代表题目清单(模板加上套路加上题单)

1. 序列型DP&#xff08;Sequence DP&#xff09; ✅ 应用场景 单个或多个序列&#xff08;数组/字符串&#xff09;&#xff0c;求最优子结构。 常见问题&#xff1a;最长递增子序列、最长公共子序列、回文子序列。 &#x1f9e0; 套路总结 单序列&#xff1a;dp[i] max(…

Linux iSCSI存储共享实验指南

实验介绍 1、在Linux平台上通过iSCSI协议实现IP-SAN存储共享 2、掌握存储导出(export)和存储导入(import)的配置方法 3、学习iSCSI存储的发现、连接、断开和管理操作 1、实验环境 两台同网段的Linux虚拟机&#xff08;无需物理交换机&#xff09; 操作系统&#xff1a;Lin…

从 Docker 到 runC

从 Docker 到 runC:容器底层原理详解 目录 1. Docker 与 runC 的关系 2. Docker 的核心组件 3. runC 的核心功能 4. 实战示例:从 Docker 到 runC 4.1 示例场景:运行一个简单容器 4.2 Docker 底层调用 runC 的流程 4.3 查看 runC 的调用 4.4 直接调用 runC 创建容器 …

使用Python在PowerPoint中插入形状(Shape)

在进行演示文稿设计时&#xff0c;形状&#xff08;Shape&#xff09;不仅可以增强视觉效果&#xff0c;还可以用于展示流程图、标注、数据图示等。借助Python&#xff0c;我们可以通过代码快速批量地在PPT中添加各种形状&#xff0c;提升设计效率。本文将介绍如何使用Python向…

Windows系统下MySQL 8.4.5压缩包安装详细教程

一、MySQL 8.4.5新特性概览 相较于旧版本&#xff0c;MySQL 8.4.5在性能与功能上实现了显著提升&#xff1a; 性能优化&#xff1a;官方测试显示&#xff0c;在高并发场景下&#xff0c;其读写性能较5.7版本提升近2倍&#xff0c;尤其在处理热点数据竞争问题时表现更为出色。…

深度解析Vue项目Webpack打包分包策略 从基础配置到高级优化,全面掌握性能优化核心技巧

深度解析Vue项目Webpack打包分包策略 从基础配置到高级优化&#xff0c;全面掌握性能优化核心技巧 一、分包核心价值与基本原理 1.1 为什么需要分包 首屏加载优化&#xff1a;减少主包体积&#xff0c;提升TTI&#xff08;Time to Interactive&#xff09;缓存利用率提升&am…

【昇腾开发者训练营:Dify大模型部署实战】MindIE + Dify + DeepSeek + Embedding模型 + Rerank模型

文章目录 部署 Dify1. Dify 适配 ARM2. 安装 docker3. 启动 Dify MindIEDify 实操手册1. 基础环境搭建1.1 环境检查1.2 下载模型权重1.3 获取MindIE镜像 2. 启动容器3. 纯模型推理测试3.1 纯模型对话测试3.2 性能测试 4. 服务化部署4.1 MindIE 配置4.2 MindIE 服务化4.3 发起测…

塔能高温冰蓄冷技术:工厂能耗精准节能的创新之路

在工厂的能耗构成中&#xff0c;制冷系统是重要的耗能环节。传统的水蓄冷和冰蓄冷技术在实际应用中存在一些局限性&#xff0c;难以满足工厂对节能和成本控制的更高要求。塔能科技的高温冰蓄冷技术&#xff0c;凭借其独特的优势&#xff0c;为工厂能耗精准节能提供了创新的解决…

通过现代数学语言重构《道德经》核心概念体系,形成一个兼具形式化与启发性的理论框架

以下是对《道德经》的数学转述尝试&#xff0c;通过现代数学语言重构其核心概念&#xff0c;形成一个兼具形式化与启发性的理论框架&#xff1a; 0. 基础公理体系 定义&#xff1a; 《道德经》是一个动态宇宙模型 U(D,V,Φ)&#xff0c;其中&#xff1a; D 为“道”的无限维…

SQLMesh Typed Macros:让SQL宏更强大、更安全、更易维护

在SQL开发中&#xff0c;宏&#xff08;Macros&#xff09;是一种强大的工具&#xff0c;可以封装重复逻辑&#xff0c;提高代码复用性。然而&#xff0c;传统的SQL宏往往缺乏类型安全&#xff0c;容易导致运行时错误&#xff0c;且难以维护。SQLMesh 引入了 Typed Macros&…

5月23日day34打卡

GPU训练及类的call方法 知识点回归&#xff1a; CPU性能的查看&#xff1a;看架构代际、核心数、线程数GPU性能的查看&#xff1a;看显存、看级别、看架构代际GPU训练的方法&#xff1a;数据和模型移动到GPU device上类的call方法&#xff1a;为什么定义前向传播时可以直接写作…

集群、容器云与裸金属服务器的全面对比分析

文章目录 引言 集群 2.1 定义 2.2 特点 2.3 应用场景 容器云 3.1 定义 3.2 核心功能 3.3 应用场景 裸金属 4.1 定义 4.2 特点 4.3 应用场景 三者的区别 5.1 架构与性能 5.2 管理与运维 5.3 成本与灵活性 总结 1. 引言 在云计算和数据中心领域&#xff0c;50…

Vscode +Keil Assistant编译报错处理

Vscode Keil Assistant编译报错处理 1.报错图片内容 所在位置 行:1 字符: 25 chcp.com 65001 -Command & c:\Users\92170.vscode\extensions\cl.keil-a … ~ 不允许使用与号(&)。& 运算符是为将来使用而保留的&#xff1b;请用双引号将与号引起来(“&”)&…

Java实现中文金额转换

概述 话不多说&#xff0c;直接上代码 代码 /*** Author: hweiyu* Description: TODO* Date: 2025/5/23 11:33*/ import java.math.BigDecimal; import java.util.Scanner;public class AmountToChinese {// 中文数字字符private static final String[] NUMBERS {"零&…

Oracle 的 ALTER DATABASE RECOVER MANAGED STANDBY DATABASE FINISH 命令

Oracle 的ALTER DATABASE RECOVER MANAGED STANDBY DATABASE FINISH 命令 ALTER DATABASE RECOVER MANAGED STANDBY DATABASE FINISH 是 Oracle Data Guard 环境中用于停止恢复过程并准备备用数据库切换为主库的关键命令。 命令用途 该命令主要用于以下场景&#xff1a; 故…

Java 依赖管理工具:使用 Sonatype Nexus 管理项目依赖

Java 依赖管理工具&#xff1a;使用 Sonatype Nexus 管理项目依赖 在 Java 开发领域&#xff0c;依赖管理是项目构建和维护过程中的关键环节。Sonatype Nexus 作为一个功能强大的依赖管理工具&#xff0c;能够有效地帮助我们管理项目的各种依赖&#xff0c;提高开发效率并降低…

编译原理 期末速成

一、基本概念 1. 翻译程序 vs 编译程序 翻译程序的三种方式 编译&#xff1a;将高级语言编写的源程序翻译成等价的机器语言或汇编语言。&#xff08;生成文件&#xff0c;等价&#xff09;解释&#xff1a;将高级语言编写的源程序翻译一句执行一句&#xff0c;不生成目标文件…

Pysnmp使用指南

1. 简介 pysnmp 是一个纯 Python 实现的 SNMP&#xff08;Simple Network Management Protocol&#xff09;库&#xff0c;支持 SNMPv1、SNMPv2c 和 SNMPv3 协议。用于&#xff1a; 查询&#xff08;GET&#xff09;和修改&#xff08;SET&#xff09;网络设备的管理信息。遍…