Java集合简单理解

Java 的集合框架(Java Collections Framework, JCF)是 Java 中用于存储和操作数据结构的核心库,提供了丰富的接口和实现类,用于处理不同类型的集合数据。以下是详细的介绍:


一、集合框架的体系结构

Java 集合主要分为两大接口:

  1. Collection 接口:存储单一元素。
    • 子接口:List(有序可重复)、Set(无序不可重复)、Queue(队列)。
  2. Map 接口:存储键值对(Key-Value)。

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-L6KW4Q8y-1742140403056)(https://i.imgur.com/3V7gXQ6.png)]


二、Collection 接口及实现类

1. List(有序、可重复)
  • 特点:元素按插入顺序存储,允许重复。
  • 常用实现类
    • ArrayList
      • 基于动态数组实现,支持快速随机访问(通过索引)。
      • 初始容量为 10,扩容时增长 50%(newCapacity = oldCapacity + oldCapacity >> 1)。
      • 线程不安全,适用于读多写少的场景。
    • LinkedList
      • 基于双向链表实现,插入和删除效率高(时间复杂度 O(1))。
      • 支持队列(Queue)和双端队列(Deque)操作。
    • Vector(已过时):
      • 线程安全的动态数组,所有方法用 synchronized 修饰,性能较差。
      • 替代方案:使用 Collections.synchronizedList(new ArrayList<>())CopyOnWriteArrayList(并发场景)。
2. Set(无序、不可重复)
  • 特点:元素唯一,不保证顺序。
  • 常用实现类
    • HashSet
      • 基于 HashMap 实现,元素存储在键的位置(值用 PRESENT 对象占位)。
      • 依赖 hashCode()equals() 保证唯一性。
      • 时间复杂度:添加、删除、查询均为 O(1)。
    • LinkedHashSet
      • 继承 HashSet,内部通过链表维护插入顺序。
      • 适合需要按插入顺序遍历的场景。
    • TreeSet
      • 基于红黑树(TreeMap)实现,元素按自然顺序或自定义 Comparator 排序。
      • 时间复杂度:添加、删除、查询均为 O(log n)。
3. Queue(队列)
  • 特点:先进先出(FIFO)或优先级的元素处理。
  • 常用实现类
    • LinkedList:可作为普通队列使用。
    • PriorityQueue
      • 基于堆结构实现,元素按优先级排序。
      • 自然顺序或通过 Comparator 定义顺序。
    • ArrayDeque
      • 基于循环数组实现的双端队列,适合高效的头尾操作。

三、Map 接口及实现类

  • 特点:键值对存储,键唯一。
  • 常用实现类
    • HashMap
      • 基于数组+链表/红黑树(Java 8+),键的哈希值决定存储位置。
      • 允许 null 键和 null 值,线程不安全。
      • 扩容机制:默认容量 16,负载因子 0.75(容量达到阈值时扩容为 2 倍)。
    • LinkedHashMap
      • 继承 HashMap,通过链表维护插入顺序或访问顺序(LRU 缓存)。
    • TreeMap
      • 基于红黑树实现,键按自然顺序或自定义 Comparator 排序。
    • Hashtable(已过时):
      • 线程安全的哈希表,被 ConcurrentHashMap 取代。
    • ConcurrentHashMap
      • 分段锁(Java 7)或 CAS + synchronized(Java 8+)实现高并发。
      • 推荐替代 Hashtable 用于多线程场景。

四、工具类 Collections

提供对集合的常用操作:

  • 排序:Collections.sort(list)
  • 线程安全包装:Collections.synchronizedList(list)
  • 不可变集合:Collections.unmodifiableList(list)
  • 查找极值:Collections.max(collection)

五、迭代器 Iterator

  • 作用:遍历集合元素。
  • fail-fast 机制
    • 在遍历过程中检测到集合被修改(如 add/remove),立即抛出 ConcurrentModificationException
    • 适用于 ArrayListHashMap 等非线程安全集合。
  • fail-safe 机制
    • 遍历时对原集合的修改不影响迭代器(如 ConcurrentHashMap 的迭代器)。

六、Java 8+ 新特性

  1. Lambda 表达式与集合
    list.forEach(element -> System.out.println(element));
    
  2. Stream API
    list.stream().filter(e -> e > 5).map(e -> e * 2).collect(Collectors.toList());
    
  3. HashMap 优化
    • 当链表长度 ≥ 8 时转换为红黑树,提高查询效率。

七、如何选择集合类?

  • 需要唯一性SetHashSetTreeSet)。
  • 需要有序性ListArrayListLinkedList)。
  • 键值对存储MapHashMapConcurrentHashMap)。
  • 多线程环境ConcurrentHashMapCopyOnWriteArrayList
  • 排序需求TreeSetTreeMap

八、示例代码

// List 示例
List<String> arrayList = new ArrayList<>();
arrayList.add("Java");
arrayList.add("Python");// Set 示例
Set<Integer> hashSet = new HashSet<>();
hashSet.add(1);
hashSet.add(2);// Map 示例
Map<String, Integer> hashMap = new HashMap<>();
hashMap.put("Apple", 10);
hashMap.put("Banana", 20);// 使用 Stream 过滤
List<Integer> numbers = Arrays.asList(1, 2, 3, 4, 5);
List<Integer> evenNumbers = numbers.stream().filter(n -> n % 2 == 0).collect(Collectors.toList());

通过理解集合框架的结构和特性,可以更高效地选择适合业务场景的数据结构。

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

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

相关文章

群体智能优化算法-旗鱼优化算法 (Sailfish Optimizer, SFO,含Matlab源代码)

摘要 旗鱼优化算法&#xff08;Sailfish Optimizer, SFO&#xff09;是一种模拟旗鱼&#xff08;Sailfish&#xff09;和沙丁鱼&#xff08;Sardine&#xff09;之间捕食关系的新型元启发式算法。通过在搜索过程中模拟旗鱼对沙丁鱼的捕食行为&#xff0c;以及沙丁鱼群的逃逸与…

【C语言】编译和链接详解

hi&#xff0c;各位&#xff0c;让我们开启今日份博客~ 小编个人主页点这里~ 目录 一、翻译环境和运行环境1、翻译环境1.1预处理&#xff08;预编译&#xff09;1.2编译1.2.1词法分析1.2.2语法分析1.2.3语义分析 1.3汇编1.4链接 2.运行环境 一、翻译环境和运行环境 在ANSI C…

VIC模型率定验证

在气候变化问题日益严重的今天&#xff0c;水文模型在防洪规划&#xff0c;未来预测等方面发挥着不可替代的重要作用。目前&#xff0c;无论是工程实践或是科学研究中都存在很多著名的水文模型如SWAT/HSPF/HEC-HMS等。虽然&#xff0c;这些软件有各自的优点&#xff1b;但是&am…

【AWS入门】AWS云计算简介

【AWS入门】AWS云计算简介 A Brief Introduction to AWS Cloud Computing By JacksonML 什么是云计算&#xff1f;云计算能干什么&#xff1f;我们如何利用云计算&#xff1f;云计算如何实现&#xff1f; 带着一系列问题&#xff0c;我将做一个普通布道者&#xff0c;引领广…

Flutter_学习记录_ ImagePicker拍照、录制视频、相册选择照片和视频、上传文件

插件地址&#xff1a;https://pub.dev/packages/image_picker 添加插件 添加配置 android无需配置开箱即用&#xff0c;ios还需要配置info.plist <key>NSPhotoLibraryUsageDescription</key> <string>应用需要访问相册读取文件</string> <key>N…

蓝桥与力扣刷题(蓝桥 星期计算)

题目&#xff1a;已知今天是星期六&#xff0c;请问 20^22 天后是星期几? 注意用数字 1 到 7 表示星期一到星期日。 本题为填空题&#xff0c;只需要算出结果后&#xff0c;在代码中使用输出语句将所填结果输出即可。 解题思路&#xff0b;代码&#xff1a; 代码&#xff1…

向量数据库原理及选型

向量数据库 什么是向量什么是向量数据库原理应用场景 向量数据库的选型主流向量数据库介绍向量数据库对比主流向量数据库对比表 选型建议 什么是向量 向量是一组有序的数值&#xff0c;表示在多维空间中的位置或方向。向量通常用一个列或行的数字集合来表示&#xff0c;这些数…

以实现生产制造、科技研发、人居生活等一种或多种复合功能的智慧油站开源了

AI视频监控平台简介 AI视频监控平台是一款功能强大且简单易用的实时算法视频监控系统。它的愿景是最底层打通各大芯片厂商相互间的壁垒&#xff0c;省去繁琐重复的适配流程&#xff0c;实现芯片、算法、应用的全流程组合&#xff0c;从而大大减少企业级应用约95%的开发成本。用…

小程序网络大文件缓存方案

分享一个小程序网络大图加载慢的解决方案 用到的相关api getSavedFileList 获取已保存的文件列表&#xff1b;getStorageSync 获取本地缓存&#xff1b;downloadFile 下载网络图片&#xff1b;saveFile 保存文件到本地&#xff1b;setStorage 将数据储存到小程序本地缓存&…

软考系统架构师 — 3 操作系统

目录 3.1 考点分析 3.1 操作系统概述 3.1.1 操作系统的功能 3.1.2 操作系统的分类 3.1.3 嵌入式操作系统主要特点 3.2 进程 3.2.1 进程的组成和状态 3.2.2 前趋图与进程资源图&#xff08;重点&#xff09; 3.2.3 进程同步与互斥 3.2.4 进程调度 3.2.5 死锁 3.3 线…

PE,ELF,COFF

本文来自 (1)腾讯元宝 (2)程序员的自我修养 PE&#xff08;Portable Executable&#xff09;是一种文件格式&#xff0c;主要用于Windows操作系统中的可执行文件&#xff08;如.exe、.dll、.sys等&#xff09;。PE格式是Windows操作系统中标准的可执行文件格式&#xff0c;由…

MySQL 在 CentOS 7 上安装的步骤指南

目录 1. 卸载不需要的环境 2. 获取 MySQL YUM 仓库 3. 安装 MySQL 4. 启动 MySQL 服务 5. 获取临时 Root 密码 6. 登录 MySQL 7. 更改 Root 密码 8. 设置 MySQL 开机自启动 9. 配置 MySQL 编码 10. 重启 MySQL 配置生效 11. 常见问题解决 1. 卸载不需要的环境 如果…

C++初阶——类和对象(三) 构造函数、析构函数

C初阶——类和对象&#xff08;三&#xff09; 上期内容&#xff0c;我们围绕类对象模型的大小计算&#xff0c;成员存储方式&#xff0c;this指针&#xff0c;以及C实现栈和C语言的比较&#xff0c;进一步认识了C的封装特性。本期内容&#xff0c;我们开始介绍类的默认成员函…

【NLP】 5. Word Analogy Task(词类比任务)与 Intrinsic Metric(内在度量)

Word Analogy Task&#xff08;词类比任务&#xff09; 定义&#xff1a;Word Analogy Task 是用于评估词向量质量的内在指标&#xff08;Intrinsic Metric&#xff09;。该任务基于这样的假设&#xff1a;如果词向量能够捕捉单词之间的语义关系&#xff0c;那么这些关系应该能…

矩阵幂(矩阵k次幂)

矩阵幂 #include<stdio.h> //矩阵乘法 void cf(int a[20][20],int b[20][20],int result[20][20],int n){for(int i0;i<n;i){for(int j0;j<n;j){result[i][j]0;for(int k0;k<n;k){result[i][j]a[i][k]*b[k][j];}}} }void print(int a[20][20],int n){for(int…

信火一体作战模式运用特点分析及对一体化防空反导能力建设的启示

文章目录 内容摘要1. 引言2. 信火一体作战模式在现代战争中的新内涵和特征2.1 充当火力和信息要素的作战单元种类更加丰富2.2 信息利用更加凸显异构平台间的数据共享和情报融合2.3 作战环节上更加强调指挥决策的敏捷性和智能化3. 增强防空反导能力的举措建议3.1 强化各类作战单…

样本是怎么估计总体的

样本是怎么估计总体的 flyfish 1. 什么是样本估计总体&#xff1f; 样本估计总体是指通过样本数据&#xff08;例如100人的身高&#xff09;推断总体参数&#xff08;例如全国人口的平均身高&#xff09;。核心方法包括&#xff1a; 点估计&#xff1a;用样本统计量直接估计…

自己动手打造AI Agent:基于DeepSeek-R1+websearch从零构建自己的Manus深度探索智能体AI-Research

第一章&#xff1a;AI Agent基础与DeepSeek-R1架构解析&#xff08;1/10&#xff09; 1.1 AI Agent技术演进与核心价值 人工智能代理&#xff08;AI Agent&#xff09;经历了从规则驱动到数据驱动的范式转移。早期基于专家系统的符号主义方法&#xff08;如MYCIN医疗诊断系统…

DeepSeek 助力 Vue3 开发:打造丝滑的表格(Table)之添加列宽调整功能,示例Table14_13可展开行的固定表头表格

前言:哈喽,大家好,今天给大家分享一篇文章!并提供具体代码帮助大家深入理解,彻底掌握!创作不易,如果能帮助到大家或者给大家一些灵感和启发,欢迎收藏+关注哦 💕 目录 DeepSeek 助力 Vue3 开发:打造丝滑的表格(Table)之添加列宽调整功能,示例Table14_13可展开行的固…