day34 集合总结

news2025/1/15 20:57:49

集合总结

一、概述

  1. 作用:存储对象的容器,代替数组的,使用更加的便捷

  2. 所处的位置:java.util

  3. 体系结构

二、Collection

  1. 内部的每一个元素都得是引用数据类型

  2. 常用方法

    • add(Object o) 添加元素

    • addAll(Collection c) 将指定集合中的所有元素存入到当前集合

    • remove(Object o) 移除元素

    • removeAll(Collection c) 删除当前集合中包含指定集合中的所有元素

    • isEmpty() 判断集合是否为空集合

    • size() 返回集合中元素的个数

    • clear() 清空集合

    • contains(Object o) :判断集合中是否包含指定的元素

    • containsAll(Collection c) 判断当前集合是否包含指定集合中的所有元素

三、List

  1. List是Collection下的一个子接口

  2. 特点:有序,可重复,有下标

  3. 常用方法

    • add(int index,Object) 将指定元素添加到当前集合指定的位置

    • remove(int index) 删除当前集合指定位置上的元素

    • get(int index) 获取当前集合中指定位置上的元素

    • set(int index, Object o) 将当前集合中指定位置上的元素替换为指定的元素

    • List subList(int a,int b) 截取当前集合中的元素获取一个子集、

四、List接口的实现类

(一)ArrayList(重点)

  1. 特点:底层封装了一个数组用于存储数据,数组默认长度为10

  2. 查询快,增删慢

  3. JDK1.2提供的

  4. 线程不安全

(二)LinkedList

  1. 特点:底层封装了链表用于存储数据,

  2. 增删快,查询慢,首尾操作极快

  3. JDK1.2提供

  4. 线程不安全

(三)Vector(了解)

  1. 内部封装一个数组用于存储数据

  2. 查询快,增删慢

  3. JDK1.0提供,最原始的集合

  4. 线程安全的

  5. Stack(栈)继承了Vector

五、遍历集合

  1. for循环遍历

  2. 新循环,增强for循环

  3. 迭代器(iterator)遍历

    • boolean hashNext() 问,是否有下一个元素

    • E next() 取,获取下一个元素

    • void remove() 删 删除当前元素

  4. forEach方法遍历 结合了Lambda表达式

六、Collections (类)

  1. java.util.Collections 是一个集合工具类

  2. 相关方法

    • Collections.sort(List list) 将集合进行升序排序

    • Collections.sort(List list, Comparator com) 自定义排序

    • Collections.reverse(List list) 将集合元素进行反转

七、Set接口

  1. 也是Collection下的子接口

  2. 特点:无序,无下标,元素不可重复

  3. 常用方法:Set的常用方法基本都是继承自Collection

八、Set接口的实现类

(一)HashSet

  1. 特点: 无序,不重复,无下标

  2. 数据存储方式:由数组 + 链表 进行存储 ,内部元素称为 entry

  3. 去重机制:hashCode()方法 + equals()方法

(二) LinkedHashSet

  1. 特点:不能重复,无下标 ,但是有序(元素插入数据顺序是有序的)

  2. 数据存储方式:由数组 + 链表 进行存储 ,内部元素称为 entry

  3. 去重机制 :hashCode()方法 + equals()方法

(三)TreeSet

  1. 特点:不能重复,无下标,有序(可以自动对集合中存入元素进行自然排序<升序>,元素必须实现Comparable接口)

  2. 数据存储方式:由数组 + 链表 进行存储 ,内部元素称为 entry,当链表中元素过多时,会通过二叉树进行排序

  3. 去重机制:根据Comparable接口中的compareTo()方法,方法返回值去过为0则表示对象相同

  4. compareTo() 比较器:

    • 返回值大于0 升序

    • 返回值等于0 相等,去重 ,

    • 返回值小于0 降序

九、Map

  1. 特点:一个元素由两个对象构成,分别作为key和value,无序,无下标,键不可以重复,值可以重复,通过键来访问

  2. 常用方法

    • put(Object key,Object value) :往Map中存放一个元素

    • get(Object key) 通过指定的key获取当前集合中的value

    • remove(Object key) 通过指定的key删除当前集合中的元素

    • size() 获取集合中元素的个数

    • keySet() : 将集合中所有的key转换成一个Set集合

    • entrySet(): 将集合中所有元素转换成一个Set集合

    • values(): 将集合中所有的value 转换成一个Collection集合

    • containsKey(Object key): 当前集合中是否包含指定的key

    • containsValue(Object value):当前集合中是否包含指定的value

  3. 遍历Map集合的四种方式

    • 遍历所有的key keySet()

    • 遍历所有的键值对 entrySet()

    • 遍历所有的value values()

    • forEach()遍历

十、Map接口的实现类

(一)HashMap(重点)

  1. 特点:无序,不重复,无下标

  2. 允许null作为key和value

  3. JDK1.2提供,线程不安全

  4. 去重机制:hashCode() + equals()

(二)LinkedHashMap

  1. 特点:不重复,无下标,有序(可以保存元素的插入顺序)

  2. 允许null作为key和value

  3. JDK1.2提供,线程不安全

  4. 去重机制:hashCode() + equals()

(三) TreeMap

  1. 特点:不重复,无下标,有序(对key自动排序(自然排序))

  2. 允许null作为key和value

  3. JDK1.2提供,线程不安全

  4. 元素必须实现Comparable接口,并重写compareTo方法

  5. 去重机制:根据compareTo方法,如果返回值为0则是同一个对象

(四)Properties

  1. 一般会创*.properties文件作为配置文件

  2. Prpperties是用于读取*.properties文件的

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

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

相关文章

【LeetCode周赛】LeetCode第362场周赛

LeetCode第362场周赛 与车相交的点判断能否在给定时间到达单元格将石头分散到网格图的最少移动次数 与车相交的点 给你一个下标从 0 开始的二维整数数组 nums 表示汽车停放在数轴上的坐标。对于任意下标 i&#xff0c;nums[i] [starti, endi] &#xff0c;其中 starti 是第 i…

讯飞星火认知大模型,多种应用一键体验整合

分享几个可以&#xff0c;直接可以使用的AI应用&#xff0c;依托于讯飞星火大模型实现的&#xff1b; 现在讯飞星火认知大模型&#xff0c;使用已经完全开放&#xff0c;可以直接使用&#xff1b; AI抖音商品种草文案 功能&#xff1a; 通过将商品信息输入到讯飞星火AI大模…

IntelliJ IDEA工具常用插件汇总

&#x1f61c;作 者&#xff1a;是江迪呀✒️本文关键词&#xff1a;IntelliJ IDEA 、常用插件☀️每日 一言&#xff1a;人的一生其实都在偏见和走出偏见中度过 文章目录 一、前言二、Plugins1.Key Promoter X2.CodeGlance3.Git Integration&#xff1a;4.Markdow…

SpringBoot整合Mybatis-Plus(含自动配置分析)

目录 1. Mybatis-Plus介绍2. 创建Mysql表和添加测试数据3. 添加pom.xml依赖4. 自动配置分析5. 代码实现5.1 User类实现5.2 指定MapperScan扫描路径5.3 Mapper接口实现5.4 Service实现5.5 UserMapper测试 1. Mybatis-Plus介绍 Mybatis-Plus是一个Mybatis的增强工具&#xff0c;…

Rich Bowen: 无论你在创造什么,最终交付的是信任。

早在开源被我们称之为开源&#xff0c;Rich Bowen 就已经参与其中。作为 Apache 软件基金会的成员&#xff0c;Rich 目前担任董事会成员、会议副总裁。此外&#xff0c;他还是亚马逊云科技的开源策略师。这些多重角色赋予了他对开源的更广泛和深刻的理解。 在他于 2023 年 Com…

远程连接mysql报错“Host xxx is not allowed to connect to this MySQL server“解决办法

在一台服务器上安装了mysql后使用dbeaver远程连接不上报错&#xff1a; 可以看到&#xff0c;报错原因是不许远程连接到mysql服务器 所以&#xff0c;修改访问权限。 首先&#xff0c;进入mysql命令行&#xff0c;查看访问权限&#xff1a; use mysql; select user,host from…

【ProxySql】Mysql如何实现读写分离?看这一篇就够了

&#x1f332;其他工具对比 其实市面上有很多关于读写分离的优秀的工具&#xff0c;例如 工具优势劣势ProxySQL- 高性能的负载均衡和连接池管理- 支持MySQL和MariaDB- 灵活的配置和规则定义- 只支持MySQL和MariaDB数据库- 功能相对专注&#xff0c;适用性可能有限- 学习和配置…

K线学习001-早晨之星1

K线定义 早晨之星&#xff0c;顾名思义&#xff1a;就是在太阳尚未升起的时候&#xff0c;黎明前最黑暗的时刻&#xff0c;一颗明亮的启明星在天边指引着那些走向光明的夜行人&#xff0c;前途当然看好。 早晨之星&#xff0c;即预示着跌势将尽&#xff0c;大盘处于拉升的前夜&…

DGIOT 智慧车间机床设备数据采集

**[小 迪 导读]**&#xff1a;DGiot掌上工厂是一款基于微信小程序的应用&#xff0c;本次主要介绍机床设备数据采集功能&#xff0c;旨在帮助施工员高效地收集车间中每台机床的信息、水平座标轴数据和照片。该小程序提供了简单易用的界面和功能&#xff0c;使施工员能够方便地记…

NameError: name ‘add start docstrings to callable‘ is not defined解决方案

大家好,我是爱编程的喵喵。双985硕士毕业,现担任全栈工程师一职,热衷于将数据思维应用到工作与生活中。从事机器学习以及相关的前后端开发工作。曾在阿里云、科大讯飞、CCF等比赛获得多次Top名次。现为CSDN博客专家、人工智能领域优质创作者。喜欢通过博客创作的方式对所学的…

中国又一款3纳米芯片将量产,高通被前后夹击,难怪要降价求售了

高通作为手机芯片市场的领先者&#xff0c;曾长达十多年位居手机芯片市场的王者地位&#xff0c;不过从2020年以来就已被中国芯片企业超越&#xff0c;至今未能挽回&#xff0c;而近期中国一家手机企业的9000S芯片推出更给予高通重击&#xff0c;可能导致高通在中国手机芯片市场…

管理类联考——数学——汇总篇——知识点突破——应用题——路程

⛲️ 路程问题是根据速度、时间、路程之间的关系&#xff0c;研究物体相向、相背和同向运动的问题&#xff0c;解决路程问题常用方法&#xff1a; &#xff08;1&#xff09;分解。将综合性的题目先分解成若干个基本题&#xff0c;再按其所属类型&#xff0c;直接利用基本数量…

【C++】list的模拟实现【完整理解版】

目录 一、list的概念引入 1、vector与list的对比 2、关于struct和class的使用 3、list的迭代器失效问题 二、list的模拟实现 1、list三个基本函数类 2、list的结点类的实现 3、list的迭代器类的实现 3.1 基本框架 3.2构造函数 3.3 operator* 3.4 operator-> 3…

四叶图-openGL 例子,第四章。计算机图形学 中例子 代码有点瑕疵

第四版 计算机图形学 中例子 代码有点瑕疵&#xff0c;见下图&#xff0c;本道长保证这个程序没有运行过。 可运行代码如下。 #include "stdafx.h" #include <GL/glut.h> #include <stdlib.h> #include <math.h> #include <iostream> using…

UG\NX二次开发 计算uv参数的最小值最大值 UF_MODL_ask_face_uv_minmax

文章作者:里海 来源网站:王牌飞行员_里海_里海NX二次开发3000例,里海BlockUI专栏,C\C++-CSDN博客 简介: UG\NX二次开发 计算uv参数的最小值最大值 UF_MODL_ask_face_uv_minmax 效果: 代码: #include "me.hpp"void ufusr(char* param, int* ret…

探索如何将html和svg导出为图片

笔者开源了一个Web思维导图&#xff0c;在做导出为图片的功能时走了挺多弯路&#xff0c;所以通过本文来记录一下。 思维导图的节点和连线都是通过 svg 渲染的&#xff0c;作为一个纯 js 库&#xff0c;我们不考虑通过后端来实现&#xff0c;所以只能思考如何通过纯前端的方式…

d3dx9_43.dll丢失如何修复?四种快速修复d3dx9_43.dll丢失的方法分享

在我们日常使用电脑的过程中&#xff0c;有时候会遇到一些问题&#xff0c;其中比较常见的一种就是电脑提示 d3dx9_43.dll 丢失。对于这种情况&#xff0c;我们该如何解决呢&#xff1f;本文将详细介绍 d3dx9_43.dll 文件的相关信息&#xff0c;以及解决 d3dx9_43.dll 丢失的四…

[hello,world]这个如何将[ ] 去掉

[hello,world]这个如何将[ ] 去掉&#xff1f; 你可以使用编程语言中的字符串处理函数来去掉方括号。以下是一个示例代码&#xff0c;使用Python的strip()函数去掉方括号&#xff1a; text "[hello,world]" text text.strip("[]") print(text)输出为&a…

CVPR:使用完全交叉Transformer的小样本目标检测

关注并星标 从此不迷路 计算机视觉研究院 公众号ID&#xff5c;ComputerVisionGzq 学习群&#xff5c;扫码在主页获取加入方式 论文地址&#xff1a; https://openaccess.thecvf.com/content/CVPR2022/papers/Han_Few-Shot_Object_Detection_With_Fully_Cross-Transformer_CVPR…

多元共进|支持多元梦想,创造包容文化环境

谷歌致力于推动多元、平等、共融 鼓励每个人赞扬自己取得的成就 了解自我展示的重要性 一起了解 2023 Google 开发者大会上 谷歌如何支持企业创造多元共融的文化 打造包容性的工作场所 为每个人创造更加温暖的环境 多元、平等、共融 (DEI)&#xff0c;三个板块之间互相联系&…