当前位置: 首页 > news >正文

Java集合1.0

1.什么是集合?

集合就是一个存放数据的容器,准确的说是放数据对象引用的容器。

集合和数组的区别

  • 数组是固定长度,集合是可变长度。
  • 数组可以存储基本数据类型,也可以存储引用数据类型,集合只能存储引用数据类型;
  • 数组存储的元素必须是同一个数据类型,集合存储的对象可以是不同的数据类型。

使用集合框架的好处

  • 容量自增长;
  • 提供了高性能的数据结构和算法,使得编码更轻松,提高了程序速度和质量;
  • 允许不同API之间相互操作,API之间可以来回传递集合;
  • 可以方便的扩展或改写集合,提高了代码的复用性和可操作性;
  • 通过使用JDK自带的集合类,可以降低代码维护和学习新API的成本;

2.常用的集合类有哪些?

Map接口和Collection接口是所有集合框架的父接口:

  1. Collection接口的子接口包括:Set接口和List接口,Queue接口;
  2. Map接口的实现类主要有:HashMap,TreeMap,HashTable,ConcurrentHashMap;
  3. Set接口的实现类主要有:HashSet,TreeSet,LinkedHashSet;
  4. List接口的实现类主要有:ArrayList,LinkedList,Stack,Vector;

3.List,Set,Map三者的区别?

  • List:
  1. 可以允许重复对象
  2. 可以插入多个null对象
  3. 是一个有序的容器,保持了每个元素的插入顺序,它的输出顺序就是插入顺序;
  4. 常用的实现类有ArrayList,LinkedList,Vector。
  • Set:
  1. 不允许重复对象
  2. 无序容器,没法保证每个元素的存储顺序,TreeSet通过Comparator或者Comparable维护了一个排序顺序
  3. 只允许一个null元素
  4. 常用的实现类是HashSet,LinkedHashSet,TreeSet
  • Map:
  1. Map里你可以拥有随意个null值,但只能有一个null键
  2. 常用的是实现类:HashMap,TreeMap,Hashtable,LinkedHashMap;

4.集合框架底层数据结构

List接口

1.ArrayList

  • 底层数据结构:动态数组
  • 特点:基于动态数组实现,数组在存储元素时是连续的内存空间;当数组容量不足时会自动扩容,通常为原容量的1.5倍;随机访问元素时O(1)的时间复杂度,但在插入或者删除元素时为O(n);

2.LinkedList

  • 底层数据结构:双向链表
  • 特点:基于双向链表实现,每个节点包含一个数据元素以及指向前后节点的两个指针;插入和删除操作O(1);随机访问O(n),因为需要从头或者尾部开始遍历链表;

3.Vector

  • 底层数据结构:动态数组
  • 特点:Vector时线程安全的,每个方法都被sychronized关键字修饰,因此在多线程环境下会出现数据不一致的问题;性能比ArrayList较差
  • 适用场景:适合多线程环境中需要频繁访问的场景,但由于Vector的性能开销,一般推荐ArrayList和同步机制配合使用;

Set接口

1.HashSet

  • 底层数据结构:哈希表
  • 特点:基于HashMap实现,哈希表使用散列函数来计算每个元素的哈希值,并将元素存储在相应的哈希桶中;HashSet不保证集合的顺序,插入,删除,查找操作的时间复杂度为O(1);允许一个null值;
  • 适用场景:需要快速查找,插入,删除,并且不关心元素顺序的场景

2.LinkedHashSet

  • 底层数据结构:链表和哈希表
  • 特点:继承自HashSet,但维护者一个双向链表以保证插入顺序;

3.TreeSet

  • 底层数据结构:红黑树(自平衡的二叉搜索树)
  • 特点:基于TreeMap实现;元素的顺序是根据提供的比较器来排序的,插入删除查找操作为O(logn);不允许null值,因为null无法比较

Map接口

1.HashMap

  • 底层数据结构:哈希表和链表/红黑树
  • 特点:基于哈希表实现,使用散列函数计算键的哈希值并将键值对存储在相应的哈希桶中;当哈希冲突发生时,HashMap使用链表来存储冲突的元素。从Java 8开始,当链表长度超过一定阈值(默认8)时,链表会转换为红黑树,以提高查找和删除效率。

2.LinkedHashMap

  • 底层数据结构:链表和哈希表
  • 特点:除了使用哈希表存储键值对外,还维护了一个双向链表来记录元素的插入顺序或访问顺序。

3.TreeMap

  • 底层数据结构:红黑树
  • 特点:底层基于红黑树实现,键值对按键的自然顺序或自定义比较器排序;不允许null键;
  • 场景:适合需要键值对有序排列和范围查找的场景。

4.Hashtable

  • 底层数据结构:哈希表
  • 特点:和HashMap类似,但Hashtable是线程安全的,所有方法都被synchronized修饰。
  • 场景:适合多线程环境下线程安全的键值对存储

5.哪些集合类是线程安全的?

  1. Vector:Vector 是一个古老的动态数组实现,所有的方法都被 synchronized 关键字修饰,因此是线程安全的。然而,由于性能较差,不推荐在现代代码中使用。
  2. Hashtable:Hashtable 是一个古老的哈希表实现,也是线程安全的,所有的方法都被 synchronized 关键字修饰。和 Vector 一样,由于性能原因,现在一般推荐使用 HashMap
  3. ConcurrentHashMap:ConcurrentHashMap 是 Java 5 及以后版本引入的并发哈希表实现。它采用分段锁机制,支持高并发的读和写操作,是一个高性能的线程安全集合类

相关文章:

Java集合1.0

1.什么是集合? 集合就是一个存放数据的容器,准确的说是放数据对象引用的容器。 集合和数组的区别 数组是固定长度,集合是可变长度。数组可以存储基本数据类型,也可以存储引用数据类型,集合只能存储引用数据类型&…...

Leetcode 336 回文对

示例 1: 输入:words ["abcd","dcba","lls","s","sssll"] 输出:[[0,1],[1,0],[3,2],[2,4]] 解释:可拼接成的回文串为 ["dcbaabcd","abcddcba","sl…...

实现一个可配置的TCP设备模拟器,支持交互和解析配置

前言 诸位在做IOT开发的时候是否有遇到一个问题,那就是模拟一个设备来联调测试,虽然说现在的物联网通信主要是用mqtt通信,但还是有很多设备使用TCP这种协议交互,例如充电桩,还有一些工业设备,TCP这类报文交…...

算法的空间复杂度

空间复杂度 空间复杂度主要是衡量一个算法运行所需要的额外空间,在计算机发展早期,计算机的储存容量很小,所以空间复杂度是很重要的。但是经过计算机行业的迅速发展,计算机的容量已经不再是问题了,所以如今已经不再需…...

自定义协议

1. 问题引入 问题:TCP是面向字节流的(TCP不关心发送的数据是消息、文件还是其他任何类型的数据。它简单地将所有数据视为一个字节序列,即字节流。这意味着TCP不会对发送的数据进行任何特定的边界划分,它只是确保数据的顺序和完整…...

在 Taro 中实现系统主题适配:亮/暗模式

目录 背景实现方案方案一:CSS 变量 prefers-color-scheme 媒体查询什么是 prefers-color-scheme?代码示例 方案二:通过 JavaScript 监听系统主题切换 背景 用Taro开发的微信小程序,需求是页面的UI主题想要跟随手机系统的主题适配…...

autogen框架中使用chatglm4模型实现react

本文将介绍如何使用使用chatglm4实现react,利用环境变量、Tavily API和ReAct代理模式来回答用户提出的问题。 环境变量 首先,我们需要加载环境变量。这可以通过使用dotenv库来实现。 from dotenv import load_dotenv_ load_dotenv()注意.env文件处于…...

读《Effective Java》笔记 - 条目9

条目9:与try-finally 相比,首选 try -with -resource 什么是 try-finally? try-finally 是 Java 中传统的资源管理方式,通常用于确保资源(如文件流、数据库连接等)被正确关闭。 BufferedReader reader n…...

【软件入门】Git快速入门

Git快速入门 文章目录 Git快速入门0.前言1.安装和配置2.新建版本库2.1.本地创建2.2.云端下载 3.版本管理3.1.添加和提交文件3.2.回退版本3.2.1.soft模式3.2.2.mixed模式3.2.3.hard模式3.2.4.使用场景 3.3.查看版本差异3.4.忽略文件 4.云端配置4.1.Github4.1.1.SSH配置4.1.2.关联…...

nextjs window is not defined

问题产生的原因 在 Next.js 中,“window is not defined” 错误通常出现在服务器端渲染(Server - Side Rendering,SSR)的代码中。这是因为window对象是浏览器环境中的全局对象,在服务器端没有window这个概念。例如&am…...

C语言实现冒泡排序:从基础到优化全解析

一、什么是冒泡排序? 冒泡排序(Bubble Sort)是一种经典的排序算法,其工作原理非常直观:通过多次比较和交换相邻元素,将较大的元素“冒泡”到数组的末尾。经过多轮迭代,整个数组会变得有序。 二…...

windows11下git与 openssl要注意的问题

看了一下自己贴文的历史,有一条重要的忘了写了。 当时帮有位同事配置gitlab,众说周知gitlab是不太好操作。 但我还是自认自己git还是相当熟的。 解决了一系列问题,如配置代理,sshkey,私有库,等等&#xff0…...

lua除法bug

故事背景,新来了一个数值,要改公式。神奇的一幕出现了,公式算出一个非常大的数。排查是lua有一个除法bug,1除以大数得到一个非常大的数。 function div(a, b)return tonumber(string.format("%.2f", a/b)) end print(1/73003) pri…...

Ubuntu下Docker容器java服务往mysql插入中文数据乱码

一、问题描述 1、java服务部署在ubuntu下的docker容器内,但是会出现部分插入中文数据显示乱码,如图所示: 二、解决方案 1、查看mysql是否支持utf8,登录进入Mysql 输入命令: mysql -u root -pshow variables like c…...

C语言根据字符串变量获取/设置结构体成员值

一、背景 在项目中需要根据从数据库中获取的字段与对应的键值付给对应结构体成员上,而c语言中没有类似的反射机制,所以需要实现类似功能。例,从表中查到a 10,在结构体t中,需要将 t.a 10。 二、实现 感谢ChatGPT&…...

Selenium 自动化测试demo

场景描述: 模拟用户登录页面操作,包括输入用户名、密码、验证码。验证码为算数运算,如下: 使用到的工具和依赖: 1. Selenium:pip install selenium 2. 需要安装浏览器驱动:这里使用的是Edge 3…...

LeetCode 111.二叉树的最小深度

题目: 给定一个二叉树,找出其最小深度。 最小深度是从根节点到最近叶子节点的最短路径上的节点数量。 说明:叶子节点是指没有子节点的节点。 思路:自底向上(归)/自顶向下(递) DF…...

大工C语言作业答案

前言 这里是大连理工大学新版C语言课程MOOC作业的答案。 后期我会把全部的作业答案开源出来&#xff0c;希望对大家有帮助。 第九周第一题 #define _CRT_SECURE_NO_WARNINGS #include <stdio.h> int B(int i) {int sum 1;while (i > 0){sum i * sum;i--;}return su…...

【Unity踩坑】Unity中父对象是非均匀缩放时出现倾斜或剪切现象

The game object is deformed when the parent object is in non-uniform scaling. 先来看一下现象 有两个Cube, Cube1&#xff08;Scale2,1,1)&#xff0c;Cube2&#xff08;Scale1,1,1&#xff09; 将Cube2拖拽为Cube2的子对象。并且将position设置为&#xff08;-0.6,1,0&a…...

QT 跨平台实现 SSDP通信 支持多网卡

一.多网卡场景 在做SSDP通信的时候,客户端发出M-search命令后, 主机没有捕捉到SSDP的消息,你可以查看下,是不是局域网下,既打开了wifi,又连接了本地网络,mac os下很容易出现这种场景。此时,我们发送消息时,需要遍历所有网卡并发送M-search命令。 二.QT相关接口介绍 1…...

Python:操作 Excel 折叠

💖亲爱的技术爱好者们,热烈欢迎来到 Kant2048 的博客!我是 Thomas Kant,很开心能在CSDN上与你们相遇~💖 本博客的精华专栏: 【自动化测试】 【测试经验】 【人工智能】 【Python】 Python 操作 Excel 系列 读取单元格数据按行写入设置行高和列宽自动调整行高和列宽水平…...

QMC5883L的驱动

简介 本篇文章的代码已经上传到了github上面&#xff0c;开源代码 作为一个电子罗盘模块&#xff0c;我们可以通过I2C从中获取偏航角yaw&#xff0c;相对于六轴陀螺仪的yaw&#xff0c;qmc5883l几乎不会零飘并且成本较低。 参考资料 QMC5883L磁场传感器驱动 QMC5883L磁力计…...

SCAU期末笔记 - 数据分析与数据挖掘题库解析

这门怎么题库答案不全啊日 来简单学一下子来 一、选择题&#xff08;可多选&#xff09; 将原始数据进行集成、变换、维度规约、数值规约是在以下哪个步骤的任务?(C) A. 频繁模式挖掘 B.分类和预测 C.数据预处理 D.数据流挖掘 A. 频繁模式挖掘&#xff1a;专注于发现数据中…...

多种风格导航菜单 HTML 实现(附源码)

下面我将为您展示 6 种不同风格的导航菜单实现&#xff0c;每种都包含完整 HTML、CSS 和 JavaScript 代码。 1. 简约水平导航栏 <!DOCTYPE html> <html lang"zh-CN"> <head><meta charset"UTF-8"><meta name"viewport&qu…...

tree 树组件大数据卡顿问题优化

问题背景 项目中有用到树组件用来做文件目录&#xff0c;但是由于这个树组件的节点越来越多&#xff0c;导致页面在滚动这个树组件的时候浏览器就很容易卡死。这种问题基本上都是因为dom节点太多&#xff0c;导致的浏览器卡顿&#xff0c;这里很明显就需要用到虚拟列表的技术&…...

【碎碎念】宝可梦 Mesh GO : 基于MESH网络的口袋妖怪 宝可梦GO游戏自组网系统

目录 游戏说明《宝可梦 Mesh GO》 —— 局域宝可梦探索Pokmon GO 类游戏核心理念应用场景Mesh 特性 宝可梦玩法融合设计游戏构想要素1. 地图探索&#xff08;基于物理空间 广播范围&#xff09;2. 野生宝可梦生成与广播3. 对战系统4. 道具与通信5. 延伸玩法 安全性设计 技术选…...

Mobile ALOHA全身模仿学习

一、题目 Mobile ALOHA&#xff1a;通过低成本全身远程操作学习双手移动操作 传统模仿学习&#xff08;Imitation Learning&#xff09;缺点&#xff1a;聚焦与桌面操作&#xff0c;缺乏通用任务所需的移动性和灵活性 本论文优点&#xff1a;&#xff08;1&#xff09;在ALOHA…...

Aspose.PDF 限制绕过方案:Java 字节码技术实战分享(仅供学习)

Aspose.PDF 限制绕过方案&#xff1a;Java 字节码技术实战分享&#xff08;仅供学习&#xff09; 一、Aspose.PDF 简介二、说明&#xff08;⚠️仅供学习与研究使用&#xff09;三、技术流程总览四、准备工作1. 下载 Jar 包2. Maven 项目依赖配置 五、字节码修改实现代码&#…...

什么是VR全景技术

VR全景技术&#xff0c;全称为虚拟现实全景技术&#xff0c;是通过计算机图像模拟生成三维空间中的虚拟世界&#xff0c;使用户能够在该虚拟世界中进行全方位、无死角的观察和交互的技术。VR全景技术模拟人在真实空间中的视觉体验&#xff0c;结合图文、3D、音视频等多媒体元素…...

云原生安全实战:API网关Envoy的鉴权与限流详解

&#x1f525;「炎码工坊」技术弹药已装填&#xff01; 点击关注 → 解锁工业级干货【工具实测|项目避坑|源码燃烧指南】 一、基础概念 1. API网关 作为微服务架构的统一入口&#xff0c;负责路由转发、安全控制、流量管理等核心功能。 2. Envoy 由Lyft开源的高性能云原生…...