List;Set;Map集合

一、List集合

  1. 概念和特点
  • 定义:List是一个有序的集合,它允许存储重复的元素。可以通过索引来访问、插入和删除元素。

  • 示例代码

    import java.util.ArrayList;
    import java.util.List;
    
    public class ListExample {
        public static void main(String[] args) {
            List<String> list = new ArrayList<>();
            list.add("apple");
            list.add("banana");
            list.add("apple");//允许重复元素
            System.out.println(list.get(0));//通过索引访问元素
        }
    }
    
  1. 主要实现类
  • ArrayList

    • 数据结构:它基于数组实现。当创建ArrayList时,会有一个初始容量(默认为10),随着元素的增加,如果容量不足,会自动扩容。

    • 性能特点:随机访问(通过索引访问元素)速度快,时间复杂度为 O ( 1 ) O(1) O(1)。但是在插入和删除元素时(特别是在中间位置),可能需要移动大量元素,插入和删除操作的时间复杂度为 O ( n ) O(n) O(n)

    • 应用场景:适用于频繁读取元素,而插入和删除操作相对较少的场景。例如,存储用户信息列表,主要操作是根据索引获取用户信息。

  • LinkedList

    • 数据结构:它是基于双向链表实现的。每个节点包含元素、指向前一个节点的引用和指向后一个节点的引用。

    • 性能特点:插入和删除操作速度快,在链表头部或尾部插入/删除元素的时间复杂度为 O ( 1 ) O(1) O(1)。但是随机访问元素的速度较慢,时间复杂度为 O ( n ) O(n) O(n)

    • 应用场景:适用于需要频繁进行插入和删除操作的场景。比如,实现一个队列或栈的数据结构。

  1. 常用方法
  • 添加元素

    • add(E element):将指定元素添加到列表的末尾。

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

  • 删除元素

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

    • remove(Object element):删除指定元素,如果列表中有多个相同元素,只删除第一个匹配的元素。

  • 访问元素

    • get(int index):返回指定索引位置的元素。
  • 其他方法

    • size():返回列表中元素的数量。

    • contains(Object element):判断列表是否包含指定元素。

二、Set集合

  1. 概念和特点
  • 定义:Set是一个不允许存储重复元素的集合。它主要用于存储无序的、唯一的元素。

  • 示例代码

    import java.util.HashSet;
    import java.util.Set;
    
    public class SetExample {
        public static void main(String[] args) {
            Set<String> set = new HashSet<>();
            set.add("apple");
            set.add("banana");
            set.add("apple");//重复元素不会被添加
            System.out.println(set.size());
        }
    }
    
  1. 主要实现类
  • HashSet

    • 数据结构:它是基于哈希表实现的。通过计算元素的哈希值来确定元素在集合中的存储位置。

    • 性能特点:添加、删除和查找元素的时间复杂度接近 O ( 1 ) O(1) O(1),性能较好。但是在哈希冲突比较严重的情况下,性能可能会下降。

    • 应用场景:适用于需要快速判断元素是否存在,对元素的顺序没有要求的场景。例如,在用户权限管理中,判断用户是否具有某种权限。

  • TreeSet

    • 数据结构:它是基于红黑树实现的。元素在集合中是按照自然顺序或者指定的比较器顺序进行排序的。

    • 性能特点:添加、删除和查找元素的时间复杂度为 O ( l o g n ) O(log n) O(logn)。因为需要维护元素的顺序,所以插入和删除操作相对较慢。

    • 应用场景:适用于需要对元素进行排序,并且不允许重复元素的场景。比如,存储学生成绩排名,需要按照成绩高低排序。

  1. 常用方法
  • 添加元素add(E element):将指定元素添加到集合中,如果元素已存在,则添加失败。
  • 删除元素remove(Object element):从集合中删除指定元素。
  • 判断元素是否存在contains(Object element):判断集合中是否包含指定元素。
  • 其他方法size():返回集合中元素的数量。

三、Map集合

  1. 概念和特点
  • 定义:Map是一种用于存储键 - 值对(key - value)的集合。每个键在Map中是唯一的,通过键可以快速获取对应的值。

  • 示例代码

    import java.util.HashMap;
    import java.util.Map;
    
    public class MapExample {
        public static void main(String[] args) {
            Map<String, Integer> map = new HashMap<>();
            map.put("apple", 1);
            map.put("banana", 2);
            System.out.println(map.get("apple"));
        }
    }
    
  1. 主要实现类
  • HashMap

    • 数据结构:它是基于哈希表实现的。通过对键进行哈希计算来确定键 - 值对在集合中的存储位置。

    • 性能特点:添加、删除和查找操作的时间复杂度接近 O ( 1 ) O(1) O(1)。但是在哈希冲突严重时,性能会受到影响。

    • 应用场景:适用于需要快速查找、插入和删除键 - 值对的场景。例如,存储用户ID和用户信息的映射关系,方便通过用户ID快速获取用户信息。

  • TreeMap

    • 数据结构:它是基于红黑树实现的。键在集合中是按照自然顺序或者指定的比较器顺序进行排序的。

    • 性能特点:添加、删除和查找操作的时间复杂度为 O ( l o g n ) O(log n) O(logn)。因为需要维护键的顺序,所以性能相对较慢。

    • 应用场景:适用于需要对键进行排序,并且按照排序后的顺序遍历键 - 值对的场景。比如,存储单词和单词出现次数的映射关系,按照字母顺序输出单词和次数。

  1. 常用方法
  • 添加/更新元素put(K key, V value):将指定的键 - 值对添加到Map中,如果键已存在,则更新对应的值。

  • 获取元素get(K key):返回指定键对应的的值,如果键不存在,则返回null。

  • 删除元素remove(K key):删除指定键对应的键 - 值对。

  • 其他方法

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

    • containsKey(K key):判断Map中是否包含指定的键。

    • containsValue(V value):判断Map中是否包含指定的值。


    凡是过去,皆为序章;凡是未来,皆有可期。

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

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

相关文章

arduino继电器与电机水泵的使用

首先说一句&#xff0c;真受不了网上的教程&#xff0c;大海里捞金&#xff0c;要不上来了就讲原理&#xff0c;怎么具体使用一句不说&#xff0c;要么炫技来了。 继电器&#xff0c;简单来说把他当开关看&#xff0c;通过小电流控制大电流(原理去看其他视频)&#xff0c;要记…

【Java Web】Axios实现前后端数据异步交互

目录 一、Promise概述 二、Promise基本用法 三、async和await关键字 四、Axios介绍 4.1 Axios基本用法 4.2 Axios简化用法之get和post方法 五、Axios拦截器 六、跨域问题处理 一、Promise概述 axios是代替原生的ajax实现前后端数据交互的一套新解决方案&#xff0c;而…

网络编程 03:端口的定义、分类,端口映射,通过 Java 实现了 IP 和端口的信息获取

一、概述 记录时间 [2024-12-19] 前置文章&#xff1a; 网络编程 01&#xff1a;计算机网络概述&#xff0c;网络的作用&#xff0c;网络通信的要素&#xff0c;以及网络通信协议与分层模型 网络编程 02&#xff1a;IP 地址&#xff0c;IP 地址的作用、分类&#xff0c;通过 …

webdriver 反爬虫 (selenium反爬虫) 绕过

1. webdriver 反爬虫原理 爬虫程序可以借助渲染工具从动态网页中获取数据。 在这个过程中&#xff0c;“借助”其实是通过对应的浏览器驱动&#xff08;即WebDriver&#xff09;向浏览器发出指令的行为。因此&#xff0c;开发者可以根据客户端是否包含浏览器驱动这一特征来区分…

JAVA 零拷贝技术和主流中间件零拷贝技术应用

目录 介绍Java代码里面有哪些零拷贝技术java 中文件读写方式主要分为什么是FileChannelmmap实现sendfile实现 文件IO实战需求代码编写实战IOTest.java 文件上传阿里云&#xff0c;测试运行代码看耗时为啥带buffer的IO比普通IO性能高&#xff1f;BufferedInputStream为啥性能高点…

系统移植——Linux 内核顶层 Makefile 详解

一、概述 Linux Kernel网上下载的版本很多NXP等有自己对应的版本。需要从网上直接下载就可以。 二、Linux内核初次编译 编译内核之前需要先在 ubuntu 上安装 lzop 库 sudo apt-get install lzop 在 Ubuntu 中 新 建 名 为 “ alientek_linux ” 的 文 件夹 &#xff0c; …

Reactor

文章目录 正确的理解发送double free问题解决 1.把我们的reactor进行拆分2.链接管理3.Reactor的理论 listensock只需要设置_recv_cb&#xff0c;而其他sock&#xff0c;读&#xff0c;写&#xff0c;异常 所以今天写nullptr其实就不太对&#xff0c;添加为空就没办法去响应事件…

【深度学习】 零基础介绍卷积神经网络(CNN)

CNN学习 零基础介绍写个CNN最简单的代码一. 概述二. 搭建CNN1. 输入层2. 卷积层3. 激活层4. 池化层5. 全连接层6. 网络搭建小结7. 损失函数8. 梯度下降9. 反向传播10. 模型评估与正则化11. 尝试搭建自己的第一个CNN 三. 经典CNN结构四. 猫狗识别项目实践1. Paddle实现版本&…

Leetcode打卡:找到稳定山的下标

执行结果&#xff1a;通过 题目&#xff1a; 3258 找到稳定山的下标 有 n 座山排成一列&#xff0c;每座山都有一个高度。给你一个整数数组 height &#xff0c;其中 height[i] 表示第 i 座山的高度&#xff0c;再给你一个整数 threshold 。 对于下标不为 0 的一座山&#xf…

leetcode刷题日记03——javascript

题目3&#xff1a; 回文数https://leetcode.cn/problems/palindrome-number/ 给你一个整数 x &#xff0c;如果 x 是一个回文整数&#xff0c;返回 true &#xff1b;否则&#xff0c;返回 false 。 回文数是指正序&#xff08;从左向右&#xff09;和倒序&#xff08;从右向…

服务器数据恢复—RAIDZ离线硬盘数超过热备盘数导致阵列崩溃的数据恢复案例

服务器存储数据恢复环境&#xff1a; ZFS Storage 7320存储阵列中有32块硬盘。32块硬盘分为4组&#xff0c;每组8块硬盘&#xff0c;共组建了3组RAIDZ&#xff0c;每组raid都配置了热备盘。 服务器存储故障&#xff1a; 服务器存储运行过程中突然崩溃&#xff0c;排除人为误操…

Tact智能合约安全实践:TON生态系统中的常见错误

TON&#xff08;The Open Network&#xff09;以其创新特性和强大的智能合约性能&#xff0c;不断拓宽区块链技术的边界。基于早期的区块链平台&#xff08;如以太坊等&#xff09;的经验与教训&#xff0c;TON为开发者提供了一个更加高效且灵活的开发环境。其中推动这一进步的…

C进阶—指针(1)

若是阁下满意的话&#xff0c;可否一键三连呢&#xff01; 第一篇进阶指针就是先了解各种新的概念&#xff08;用法我们后面几篇再详细说&#xff01;先只介绍概念&#xff09;&#xff0c;有疑惑很正常&#xff0c;只是暂时的&#xff0c;我们一起来看看吧&#xff01; 字符指…

【Python使用】嘿马头条项目从到完整开发教程第9篇:缓存,1 缓存穿透【附代码文档】

本教程的知识点为:简介 1. 内容 2. 目标 产品效果 ToutiaoWeb虚拟机使用说明 数据库 理解ORM 作用 思考&#xff1a; 使用ORM的方式选择 数据库 SQLAlchemy操作 1 新增 2 查询 all() 数据库 分布式ID 1 方案选择 2 头条 使用雪花算法 &#xff08;代码 toutiao-backend/common/…

谷歌浏览器的扩展程序自动更新设置

谷歌浏览器是全球最受欢迎的网络浏览器之一&#xff0c;其扩展程序更是为用户提供了丰富的功能。然而&#xff0c;随着时间的推移&#xff0c;扩展程序需要更新以修复漏洞、提升性能或增加新功能。本文将详细介绍如何在Chrome中设置扩展程序的自动更新。&#xff08;本文由http…

LabVIEW与PLC点位控制及OPC通讯

在工业自动化中&#xff0c;PLC通过标准协议&#xff08;如Modbus、Ethernet/IP等&#xff09;与OPC Server进行数据交换&#xff0c;LabVIEW作为上位机通过OPC客户端读取PLC的数据并进行监控、控制与处理。通过这种方式&#xff0c;LabVIEW能够实现与PLC的实时通信&#xff0c…

在Windows Server路由和远程访问服务中启用L2TP/IPsec VPN

背景 路由和远程访问服务&#xff08;Routing and Remote Access Services&#xff0c;RRAS&#xff09;是Windows Server上的一个角色&#xff0c;包含很多功能&#xff0c;可以用来搭建VPN。然而&#xff0c;在什么也不做的初始配置中&#xff0c;它只允许PPTP协议连接。然而…

Android简洁缩放Matrix实现图像马赛克,Kotlin

Android简洁缩放Matrix实现图像马赛克&#xff0c;Kotlin 原理&#xff0c;通过Matrix把一个原图缩小到原先的1/n&#xff0c;然后再把缩小后的小图放大n倍&#xff0c;自然就是马赛克效果&#xff08;相当于是放大后像素“糊”成一片了&#xff09;。 import android.content.…

《Posterior Collapse and Latent Variable Non-identifiability》

看起来像一篇很有用的paper&#xff0c;而且还是23年的 没看完 后边看不懂了 Abstract 现有的解释通常将后验崩塌归因于由于变分近似而使用神经网络或优化问题。 而本文认为后验崩塌是潜在变量不可识别性的问题(a problem of latent variable non-identifiability) 本文证明了…

网络视频监控平台/安防监控/视频综合管理Liveweb视频汇聚平台解决方案

一、当前现状分析 当前视频资源面临以下问题&#xff1a; 1&#xff09;不同单位在视频平台建设中以所属领域为单位&#xff0c;设备品牌众多&#xff0c;存在的标准不一&#xff0c;各系统之间也没有统一标准&#xff1b; 2&#xff09;各单位视频平台建设分散、统筹性差&am…