java基础从入门到上手(九):Java - List、Set、Map

news2025/4/21 9:56:22

一、List集合

        List 是一种用于存储有序元素的集合接口,它是 java.util 包中的一部分,并且继承自 Collection 接口。List 接口提供了多种方法,用于按索引操作元素,允许元素重复,并且保持插入顺序。常用的 List 实现类包括 ArrayList、LinkedList 和 Vector。

1.1概述

        List 接口继承自 Collection 接口,它支持按索引访问元素。与 Set 不同,List 允许存储重复元素,并且可以通过索引获取、插入和删除元素。

List 常用方法:

add(E e):将元素 e 添加到列表的末尾。

add(int index, E element):将元素 element 插入到指定的索引位置。

get(int index):返回指定位置的元素。

set(int index, E element):将指定位置的元素替换为新的元素。

remove(int index):删除指定位置的元素。

remove(Object o):删除指定的元素。

size():返回列表的元素个数。

isEmpty():检查列表是否为空。

contains(Object o):检查列表是否包含指定元素。

indexOf(Object o):返回元素首次出现的位置(如果不包含则返回 -1)。

lastIndexOf(Object o):返回元素最后一次出现的位置。

clear():清空列表。

1.2 实现类

1.2.1 ArrayList

ArrayList 是最常用的 List 实现,它基于动态数组来存储元素,支持快速的随机访问。

优点:

1.提供快速的访问操作(get 和 set)。

2.插入和删除元素时,位于末尾的操作非常高效。

缺点:

1.插入和删除元素时,尤其是对中间位置的元素,性能较差,因为需要移动元素。

1.2.2 LinkedList

LinkedList 是 List 接口的另一个实现,它基于双向链表实现,因此在插入和删除元素时效率较高,尤其是在列表的头部和中间位置。

优点:

  1. 插入和删除操作(尤其是在头部或中间位置)性能较好。
  2. 支持队列和栈的操作(通过 offer、poll、push 和 pop 方法)。

缺点:

  1. 随机访问性能较差,特别是当需要访问列表中的元素时,它需要从头部或尾部开始遍历。

1.2.3 Vector

Vector 类与 ArrayList 类类似,也基于动态数组实现,但与 ArrayList 的区别在于,Vector 是线程安全的(每个方法都使用 synchronized 关键字进行同步)。但由于同步的开销,它的性能通常较差。

优点:

  1. 线程安全。

缺点:

  1. 性能较差,因为所有的方法都进行了同步操作。
  2.  不推荐在新代码中使用。

二、Set集合

Set 是一个不允许重复元素的集合接口。它继承自 Collection 接口,并且提供了与 List 不同的行为:Set 不保证元素的插入顺序,并且不允许包含重复元素。因此,Set 在应用程序中用于需要保证元素唯一性的场景。

Set 接口代表一个集合,主要特点如下:

  1. 不允许包含重复的元素。
  2. 不保证元素的顺序(但某些实现可能会有顺序,如 LinkedHashSet)。
  3. 基本操作包括添加、删除和查找元素。

Set 接口的常见实现类包括:

  1. HashSet:最常用的实现类,基于哈希表,不保证元素的顺序。
  2. LinkedHashSet:与 HashSet 类似,但它保持插入顺序。
  3. TreeSet:基于红黑树实现,按元素的自然顺序(或自定义的比较器)对元素进行排序。

Set 接口的常用方法

add(E e):将元素 e 添加到集合中。如果集合已经包含该元素,则返回 false。

remove(Object o):删除指定的元素。

contains(Object o):检查集合中是否包含指定的元素。

size():返回集合中的元素数量。

isEmpty():检查集合是否为空。

clear():清空集合中的所有元素。

iterator():返回集合元素的迭代器,通常用于遍历集合。

2.1 HashSet

HashSet 是最常用的 Set 实现,基于哈希表实现,不保证元素的顺序。它的操作通常是快速的(平均时间复杂度为 O(1)),但不保证插入顺序。

2.2 LinkedHashSet

LinkedHashSet 继承自 HashSet,它保持元素的插入顺序(通过链表维护插入顺序)。与 HashSet 相比,LinkedHashSet 的插入操作稍慢一些,但它保证了元素的顺序。

2.3 TreeSet

TreeSet 是一个基于红黑树实现的 Set,它会自动按元素的自然顺序(或指定的比较器)对元素进行排序。TreeSet 中的元素是有序的,因此它支持基于排序的操作(如查找最小元素、最大元素等)。

2.4 应用场景

去重:Set 常用于去重操作,因为它不允许包含重复元素。可以利用 Set 来确保数据的唯一性。

集合运算:可以使用 Set 来进行集合的并集、交集和差集操作。Set 提供了 retainAll(交集)、removeAll(差集)和 addAll(并集)等方法。

三、Map集合

Map 是一个用于存储键值对(key-value)映射的集合接口。Map 与 Set 和 List 不同,因为它是根据键(key)来存储值(value)的,而不是按照元素的顺序或索引顺序。Map 接口并不继承自 Collection 接口,虽然它也可以存储多个对象,但它的结构是以键值对的形式组织的。

主要特点:

  1. 键唯一:Map 中的每个键都是唯一的,但多个键可以对应相同的值。
  2. 无序性:Map 本身并不保证键值对的存储顺序,但是一些实现类(如 LinkedHashMap)可以保证顺序。
  3. 支持快速查找:通过键可以非常高效地找到对应的值。

3.1 HashMap

HashMap 是最常用的 Map 实现类,基于哈希表实现,不保证键值对的顺序。它的查找和插入操作平均时间复杂度是 O(1),非常高效。

3.2 LinkedHashMap

LinkedHashMap 继承自 HashMap,除了基于哈希表存储元素外,还通过链表维护键值对的插入顺序。它保证了元素的插入顺序,因此适用于需要顺序存储的场景。

3.3 TreeMap

TreeMap 是一个有序的 Map 实现类,它基于红黑树实现,按键的自然顺序(或通过构造时提供的比较器)对键值对进行排序。它支持键值对的排序操作。

3.4 Hashtable

Hashtable 是一个古老的线程安全的 Map 实现,它的行为类似于 HashMap,但它是同步的,因此比 HashMap 更慢。由于现代 Java 程序更倾向于使用 ConcurrentHashMap 或其他线程安全的集合类,Hashtable 现在很少使用。

3.5Map 接口常用方法

put(K key, V value):将指定的值与指定的键关联。如果键已经存在,则更新值。

get(Object key):返回指定键所映射的值。如果键不存在,返回 null。

containsKey(Object key):检查 Map 是否包含指定的键。

containsValue(Object value):检查 Map 是否包含指定的值。

remove(Object key):删除指定键的键值对。

size():返回 Map 中键值对的数量。

isEmpty():检查 Map 是否为空。

clear():清空 Map 中的所有键值对。

keySet():返回 Map 中所有键的集合。

values():返回 Map 中所有值的集合。

entrySet():返回 Map 中所有键值对的集合,Map.Entry 是 Map 键值对的表示。

通过以上内容便可轻松学习java 的集合类.是不是超级简单.有任何问题欢迎留言哦!!!

重点!重点!重点!

遇到问题不用怕不如来我的知识库找找看,也许有意想不到的收获!!!

易网时代-易库资源-易库教程:.NET开发、Java开发、PHP开发、SqlServer技术、MySQL技术-开发资料大全-易网时代-易库资源-易库教程 (escdns.com)

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

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

相关文章

从malloc到free:动态内存管理全解析

1.为什么要有动态内存管理 我们已经掌握的内存开辟方法有: int main() {int val 20;//在栈空间上开辟四个字节char arr[20] { 0 };//在栈空间上开辟10个字节的连续空间return 0; }上述开辟的内存空间有两个特点: 1.空间开辟的时候大小已经固定 2.数组…

AutoSAR从概念到实践系列之MCAL篇(二)——Mcu模块配置及代码详解(上)

欢迎大家学习我的《AutoSAR从概念到实践系列之MCAL篇》系列课程,我是分享人M哥,目前从事车载控制器的软件开发及测试工作。 学习过程中如有任何疑问,可底下评论! 如果觉得文章内容在工作学习中有帮助到你,麻烦点赞收藏评论+关注走一波!感谢各位的支持! 根据上一篇内容中…

【数据库】事务

目录 1. 什么是事务? 2. 事务的ACID特性 3. 为什么使用事务? 4. 如何使用事务 4.1 查看支持事务的存储引擎 4.2 语法 4.3 保存点 4.4 自动/手动提交事务 5. 事物的隔离性和隔离级别 5.1 什么是隔离性 5.2 隔离级别 5.3 查看和设置隔离级别 1…

使用Redis实现实时排行榜

为了实现一个实时排行榜系统,我们可以使用Redis的有序集合(ZSet),其底层通常是使用跳跃表实现的。有序集合允许我们按照分数(score)对成员(member)进行排序,因此非常适合…

6. 字符串

1.反转字符串 2.替换数字 3.反转字符串中的单词 4.KMP算法 5.重复的子字符串(看具体证明) 太6了(真不是人做的)

Redis ④-通用命令

Redis 是一个 客户端-服务器 结构的程序,这与 MySQL 是类似的,这点需要牢记!!! Redis 固然好,但也不是任何场景都适合使用 Redis,一定要根据当前的业务需求来选择是否使用 Redis Redis 通用命令…

卷积神经网络(CNN)与VGG16在图像识别中的实验设计与思路

卷积神经网络(CNN)与VGG16在图像识别中的实验设计与思路 以下从基础原理、VGG16架构解析、实验设计步骤三个层面展开说明,结合代码示例与关键参数设置,帮助理解其应用逻辑。 一、CNN与VGG16的核心差异 基础CNN结构 通常包含33~55个…

玩机搞机基本常识-------小米OLED屏幕机型怎么设置为永不休眠_手机不息屏_保持亮屏功能 拒绝“烧屏” ?

前面在帮一位粉丝解决小米OLED机型在设置----锁屏下没有永不休眠的问题。在这里,大家要明白为什么有些小米机型有这个设置有的没有的原因。区分OLED 屏幕和 LCD屏幕的不同。从根本上拒绝烧屏问题。 OLED 屏幕的一些优缺点💝💝💝 …

2021-11-14 C++三七二十一数

缘由c编程怎么写&#xff0c;紧急求解-编程语言-CSDN问答 void 三七二十一数() {//缘由https://ask.csdn.net/questions/7566632?spm1005.2025.3001.5141int n 0, a 0, b 0, p 1;std::cin >> n;while (n--){std::cin >> a >> b;while (a<b){if (a %…

安全生产责任制考核方案与风险评估

安全生产责任制考核方案旨在通过有效落实国家安全生产法律法规&#xff0c;确保煤矿及相关单位的安全管理机制建立与运行&#xff0c;减少生产安全事故的发生。方案强调通过定期的量化考核和系统化评估&#xff0c;确保安全生产责任的有效落实。考核涉及集团公司各单位及相关人…

强制重装及验证onnxruntime-gpu是否正确工作

#工作记录 我们经常会遇到明明安装了onnxruntime-gpu或onnxruntime后&#xff0c;无法正常使用的情况。 一、强制重新安装 onnxruntime-gpu 及其依赖 # 强制重新安装 onnxruntime-gpu 及其依赖 pip install --force-reinstall --no-cache-dir onnxruntime-gpu1.18.0 --extra…

设计模式 --- 外观模式

外观模式是一种结构型设计模式&#xff0c;为复杂子系统提供​​统一的高层接口​​&#xff0c;通过定义一个外观类来​​简化客户端与子系统的交互​​&#xff0c;降低系统耦合度。这种模式隐藏了子系统的复杂性&#xff0c;将客户端与子系统的实现细节隔离开来&#xff0c;…

用python脚本怎么实现:把一个文件夹里面.png文件没有固定名称,复制到另外一个文件夹按顺序命名?

环境&#xff1a; python3.10 Win10 问题描述&#xff1a; 用python脚本怎么实现&#xff1a;怎么把一个文件夹里面.png文件没有固定名称&#xff0c;复制到另外一个文件夹按顺序命名&#xff1f; 解决方案&#xff1a; 1.新建一个脚本文件&#xff0c;内容如下&#xff1…

山东大学软件学院创新项目实训开发日志(20)之中医知识问答自动生成对话标题bug修改

在原代码中存在一个bug&#xff1a;当前对话的标题不是现有对话的用户的第一段的前几个字&#xff0c;而是历史对话的第一段的前几个字。 这是生成标题的逻辑出了错误&#xff1a; 当改成size()-1即可

ZYNQ笔记(十):XADC (PS XDAC 接口)

版本&#xff1a;Vivado2020.2&#xff08;Vitis&#xff09; 任务&#xff1a;通过 PS XADC 接口读取XADC测量的芯片温度、供电电压&#xff0c;并通过串口打印出来 目录 一、介绍 二、硬件设计 三、软件设计 四、效果 一、介绍 XADC&#xff08;Xilinx Analog-to-Digital…

【C++】多态 - 从虚函数到动态绑定的核心原理

&#x1f4cc; 个人主页&#xff1a; 孙同学_ &#x1f527; 文章专栏&#xff1a;C &#x1f4a1; 关注我&#xff0c;分享经验&#xff0c;助你少走弯路 文章目录 1. 多态的概念2. 多态的定义及实现2.1 多态的构成条件2.1.1实现多态还有两个必须重要条件&#xff1a;2.1.2 虚…

免费图片软件,可矫正倾斜、调整去底效果

软件介绍 有个超棒的软件要给大家介绍一下哦&#xff0c;它就是——ImgTool&#xff0c;能实现图片漂白去底的功能&#xff0c;而且重点是&#xff0c;它是完全免费使用的呢&#xff0c;功能超强大&#xff01; 软件特点及使用便捷性 这软件是绿色版本的哟&#xff0c;就像一…

Kubernetes(k8s)学习笔记(二)--k8s 集群安装

1、kubeadm kubeadm 是官方社区推出的一个用于快速部署 kubernetes 集群的工具。这个工具能通过两条指令完成一个 kubernetes 集群的部署&#xff1a; 1.1 创建一个 Master 节点$ kubeadm init 1.2 将一个 Node 节点加入到当前集群中$ kubeadm join <Master 节点的 IP 和…

【论文阅读笔记】模型的相似性

文章目录 The Platonic Representation Hypothesis概述表征收敛的依据表征收敛的原因实验依据未来发展的局限性 Similarity of Neural Network Representations Revisited概述问题背景相似性度量s的性质可逆线性变换不变性正交变换不变性各向同性缩放不变性典型度量满足的性质 …

扣子智能体1:创建Agent与写好提示词

文章目录 Agent是什么使用扣子创建智能体写好提示词生成故事发布Agent 最近学了很久多agent协同、编排工作流等与agent有关的内容&#xff0c;这里用一系列博客&#xff0c;把这些操作都一步一个脚印的记录下来。 这里我们以一个Agent为例&#xff1a;睡前灵异小故事 Agent是…