挖掘Java集合:深入探索List接口与HashSet

文章目录

    • 引言
    • LinkedList:双向链表的实现
    • 构造方法
    • LinkedList中的常用方法
    • HashSet:无序且唯一的集合
    • HashSet的实现方式
    • LinkedHashSet:有序且唯一
    • 可变长度参数
    • 结论

在这里插入图片描述

引言

在广阔的Java编程领域中,集合就如同宝库,提供了多种工具和数据结构来高效地管理数据。其中,List接口和HashSet实现作为基本组件,各自具有独特的特点和用途。在本篇文章中,我们将深入了解LinkedList类,探索HashSet以及它的衍生类LinkedHashSet,并涉及可变长度参数的概念。
在这里插入图片描述

LinkedList:双向链表的实现

Java的集合框架中,LinkedList是一个基础类,它基于双向链表的概念,每个元素都持有对前一个和后一个元素的引用。LinkedList以其快速的插入和删除操作而闻名,但查询性能较慢。

// 创建一个LinkedList实例
LinkedList<String> linkedList = new LinkedList<>();

在这里插入图片描述

构造方法

LinkedList提供了多种构造方法,以多种方式创建实例。其中两个关键的构造方法是:

  1. LinkedList():构造一个空列表。
  2. LinkedList(Collection<? extends E> c):构造一个包含指定集合的元素的列表,元素按照集合迭代器的返回顺序排列。
    在这里插入图片描述

LinkedList中的常用方法

LinkedList提供了一系列方法,满足各种需求:

  • void addFirst(E e):在列表开头插入指定元素。
  • void addLast(E e):在列表末尾添加指定元素。
  • E getFirst():返回列表中的第一个元素。
  • E getLast():返回列表中的最后一个元素。
  • E removeFirst():移除并返回列表中的第一个元素。
  • E removeLast():移除并返回列表中的最后一个元素。
  • void push(E e):将元素推入由列表表示的堆栈。
  • E pollFirst():检索并移除列表的第一个元素,如果列表为空则返回null。
  • E pollLast():检索并移除列表的最后一个元素,如果列表为空则返回null。
// 示例演示部分LinkedList的常用方法
linkedList.addFirst("First");
linkedList.addLast("Last");
String firstElement = linkedList.getFirst();
String lastElement = linkedList.getLast();
String removedFirst = linkedList.removeFirst();
String removedLast = linkedList.removeLast();

在这里插入图片描述

HashSet:无序且唯一的集合

HashSet是Set接口的一种实现,它保证不包含重复元素且无特定顺序。HashSet的实现基于底层的HashMap,其中元素被视为键。

// 创建一个HashSet实例
HashSet<String> hashSet = new HashSet<>();

在这里插入图片描述

HashSet的实现方式

  • JDK 1.8之前:数组 + 链表
  • JDK 1.8及以后:数组 + 链表 + 红黑树

向HashSet添加元素时,会检查元素的hashCode值。如果hashCode在数组中不存在,元素将被存储。如果hashCode存在,则使用equals方法比较值。如果值匹配,不进行存储;否则,使用链表结构进行存储。在JDK 1.8及以后,如果链表的长度大于等于8,将会转化为红黑树结构。

LinkedHashSet:有序且唯一

LinkedHashSet是HashSet的扩展,保留了插入顺序的同时确保唯一性。它结合了HashSet和LinkedList的特点,适用于需要保持顺序和独特性的场景。

// 创建一个LinkedHashSet实例
LinkedHashSet<String> linkedHashSet = new LinkedHashSet<>();

可变长度参数

在Java中,方法可以使用省略号...接受相同类型的可变数量参数,这些参数在方法内部被视为数组。然而,有两点要记住:

  • 如果与其他参数组合使用,可变长度参数必须放在参数列表的最后。
  • 方法的参数列表中只能使用一次可变长度参数。
// 示例演示可变长度参数的使用
public void printItems(String... items) {
    for (String item : items) {
        System.out.println(item);
    }
}

在这里插入图片描述

结论

List接口、LinkedList、HashSet和LinkedHashSet提供了不同的数据管理方式。通过了解它们的特性、构造方法和方法,开发人员可以根据项目需求明智地选择使用哪种集合。可变长度参数在参数数量不确定时提供了灵活性。在Java的集合世界中,这些工具使开发人员能够编写高效且富有表现力的代码。

在这里插入图片描述

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

C语言 用数组名作函数参数

当用数组名作函数参数时&#xff0c;如果形参数组中各元素的值发生变化&#xff0c;实参数组元素的值随之变化。 1.数组元素做实参的情况&#xff1a; 如果已经定义一个函数&#xff0c;其原型为 void swap(int x,int y);假设函数的作用是将两个形参&#xff08;x,y&#xf…

ArcGIS制作带蒙版的遥感影像地图

这次文章我们来介绍一下&#xff0c;如何通过一个系统的步骤完成ArcGIS制作带蒙版的遥感影像地图。 主要的步骤包括&#xff1a; 1 添加行政区划数据 2 导出兴趣去乡镇矢量范围 3 添加遥感影像底图 4 制作蒙版 5 利用自动完成面制作蒙版 6 标注乡镇带晕渲文字 7 …

01《Detecting Software Attacks on Embedded IoT Devices》随笔

2023.08.05 今天读的是一篇博士论文 论文传送门&#xff1a;Detecting Software Attacks on Embedded IoT Devices 看了很长时间&#xff0c;发现有一百多页&#xff0c;没看完&#xff0c;没看到怎么实现的。 摘要 联网设备的增加使得嵌入式设备成为各种网络攻击的诱人目标&…

Cloud Studio实战——热门视频Top100爬虫应用开发

最近Cloud Studio非常火&#xff0c;我也去试了一下&#xff0c;感觉真的非常方便&#xff01;我就以Python爬取B站各区排名前一百的视频&#xff0c;并作可视化来给大家分享一下Cloud Studio&#xff01;应用链接&#xff1a;Cloud Studio实战——B站热门视频Top100爬虫应用开…

lwip不同的socket分别作为监听和客户端连接

在LWIP中&#xff0c;一个网络设备&#xff08;如以太网卡&#xff09;可以创建多个socket&#xff0c;用于处理不同的网络连接。一般&#xff0c;你可以创建一个socket用于监听&#xff08;listen&#xff09;连接&#xff0c;另一个socket用于主动发起&#xff08;connect&am…

华为OD机试(含B卷)真题2023 算法分类版,58道20个算法分类,如果距离机考时间不多了,就看这个吧,稳稳的

目录 一、数据结构1、线性表2、优先队列3、滑动窗口4、二叉树5、并查集6、栈 二、算法1、基础算法2、字符串3、图4、动态规划5、数学 三、漫画算法2&#xff1a;小灰的算法进阶参与方式 很多小伙伴问我&#xff0c;华为OD机试算法题太多了&#xff0c;知识点繁杂&#xff0c;如…

jenkins使用gitlab标签发布

关于jenkins git parameter使用gitlab标签发布和分支发布的用法 手动配置的我就不说了&#xff0c;点点点就行&#xff0c;主要是说一下在pipeline里如何使用 通过分支拉取gitlab仓库代码 pipeline {agent anyenvironment {}parameters {gitParameter(branch: , branchFilte…

ASP.NET Core学习路线图

说明 1. 先决条件 - [C#](https://www.pluralsight.com/paths/csharp) - [Entity Framework](https://www.pluralsight.com/search?qentity%20framework%20core) - [ASP.NET Core](https://www.pluralsight.com/search?qasp.net%20core) - SQL基础知识 2. 通用开发技能 -…

vue3+vite配置多入口文件

1.修改vite.config.ts 文件&#xff1a; 2.在src目录底下建相应的html文件和对应的ts入口文件和vue文件&#xff0c;如下图&#xff1a; npm run dev运行后本地访问&#xff1a; http://127.0.0.1:5173/home_index.htmlnpm run build打包后的结构如图&#xff1a;

Android Studio翻译插件

进入File->Settings->Plugins界面&#xff0c;搜索Translation&#xff0c;选择这个 重启AS后&#xff0c;选中目标单词右键点击Translate即可&#xff1a;

官宣了!Nank南卡耳机签约世界游泳冠军傅园慧!共塑国货好品质

骨传导开放式耳机行业领导品牌Nank南卡今日宣布&#xff0c;将邀请世界游泳冠军傅园慧为品牌形象代言人&#xff0c;Nank南卡对品牌推广大使的选择并非跟随流量的潮向&#xff0c;而是甄选与自身价值观更为相符的游泳冠军。赛场上的傅园慧所体现的不怕输、不放弃&#xff0c;坚…

[LitCTF 2023]Http pro max plus

打开环境后提示说&#xff0c;只允许在本地访问&#xff0c;本地访问&#xff0c;还是想到了XFF字段 好家伙的&#xff0c;直接被嘲讽&#xff0c;还是了解太少了&#xff0c;都不知道还有没有其他方式可以控制ip地址信息 经过查看wp&#xff0c;得知一种新的方式 Client-IP …

【MySQL】基础知识(一)

MySQL基础知识&#xff08;一&#xff09; 文章目录 MySQL基础知识&#xff08;一&#xff09;00 MySQL安装01 数据库介绍1.1 什么是数据库1.2数据库分类 02 SQL分类03 数据库操作3.1显示数据库3.2创建数据库3.3选中数据库3.4删除数据库 04 常用数据类型4.1数值类型4.2字符串类…

用于实体对齐的联合学习实体和关系表示2019 AAAI 8.7+8.8

用于实体对齐的联合学习实体和关系表示 摘要介绍相关工作实体对齐图卷积网络 问题公式我们的方法整体架构初步实体对齐图卷积层对齐训练 近似关系表示联合实体和关系对齐 实验总结 摘要 实体对齐是在不同知识图之间集成异构知识的一种可行方法。该领域的最新发展通常采用基于嵌…

数字电路基础(MOS管)

1.PMOS和NMOS MOS晶体管的物理结构如下&#xff0c;由衬底和注入粒子的材质不同分为PMOS和NMOS。 2.CMOS CMOS由PMOS和NMOS组成&#xff0c;是一个反相器&#xff0c;其电路图如下所示。当In为1时&#xff0c;PMOS断开&#xff0c;NMOS导通&#xff0c;Out输出为0&#xff1b;…

Springboot @Validated注解详细说明

在Spring Boot中&#xff0c;Validated注解用于验证请求参数。它可以应用在Controller类或方法上 1、引入依赖 <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-validation</artifactId> </depen…

【工程优化问题】基于多种智能优化算法的压力容器设计问题研究(Matlab代码实现)

&#x1f4a5;&#x1f4a5;&#x1f49e;&#x1f49e;欢迎来到本博客❤️❤️&#x1f4a5;&#x1f4a5; &#x1f3c6;博主优势&#xff1a;&#x1f31e;&#x1f31e;&#x1f31e;博客内容尽量做到思维缜密&#xff0c;逻辑清晰&#xff0c;为了方便读者。 ⛳️座右铭&a…

【Docker】docker镜像+nginx部署vue项目:

文章目录 一、文档&#xff1a;二、打包vue项目&#xff1a;三、配置nginx&#xff1a;四、配置Dockerfile&#xff1a;五、构建镜像&#xff1a;六、运行容器&#xff1a;七、最终效果&#xff1a; 一、文档&#xff1a; 【1】菜鸟教程&#xff1a;https://www.runoob.com/do…

vscode插件不能搜索安装

1 现象 vscode搜索自己的插件&#xff0c;报错&#xff1a; Error while fetching extensions. HXR failed2 原因 之前用vscode开发golang语言&#xff0c;设置了proxy代理&#xff0c;所以导致错误&#xff0c;删除即可 重启vscode 3 结果

【Spring】使用注解存储Bean对象

目录 一、配置扫描路径&#xff08;使用注解的方式存对象的前提&#xff09; 二、使用类注解存储Bean对象 1、使用五大类注解存储Bean对象 2、为什么要这么多的类注解&#xff1f; 2.1、五大类注解之间的关系 3、获取Bean对象时的默认命名规则 三、使用方法注解来存储…