Java基础---集合类

news2025/1/7 10:36:05

目录

典型回答

Collection和Collections有什么区别

Java中的Collection如何遍历迭代

Iterable和Iterator如何使用

为什么不把Iterable和Iterator合成一个使用

哪些集合类是线程安全的


  • 典型回答

  • 什么是集合
    • 集合就是一个放数据的容器,准确的说是放数据对象引用的容器
    • 集合类存放的都是对象的引用,而不是对象的本身
    • 集合类型主要有3种:set(集)、list(列表)和map(映射)
  • 集合的特点主要有如下两点:
    • 集合用于存储对象的容器,对象是用来封装数据,对象多了也需要存储集中式管理
    • 和数组对比对象的大小不确定;因为集合是可变长度的,数组需要提前定义大小
  • Java的整个集合框架中,主要分为List,Set,Queue,Stack,Map等五种数据结构
  • 其中,前四种数据结构都是单一元素的集合,而最后的Map则是以KV对的形式使用
  • 从继承关系上讲,List,Set,Queue都是Collection的子接口,Collection又继承了Iterable接口,说明这几种集合都是可以遍历的

  • 从功能上讲,List代表一个容器,可以是先进先出,也可以是先进后出
  • 而Set相对于List来说,是无序的,同时也是一个去重的列表,既然会去重,就一定会通过equals,compareTo,hashCode等方法进行比较
  • Map则是KV的映射,也会涉及到Key值的查询等能力
  • 从实现上讲,List可以有链表实现或者数组实现,两者各有优劣,链表增删快,数组查询快
  • Queue则可以分为优先队列,双端队列等等
  • Map则可以分为普通的HashMap和可以排序的TreeMap等等
  • Collection和Collections有什么区别

  • 1-Collection 是一个集合接口:它提供了对集合对象进行基本操作的通用接口方法
    • Collection接口在Java 类库中有很多具体的实现
    • 是list,set等的父接口
  • 2-Collections 是一个包装类:它包含有各种有关集合操作的静态多态方法
    • 此类不能实例化,就像一个工具类,服务于Java的Collection框架
  • 日常开发中,不仅要了解Java中的Collection及其子类的用法,还要了解Collections用法
  • 可以提升很多处理集合类的效率
  • Java中的Collection如何遍历迭代

  • 1-传统的for循环遍历,基于计数器的:遍历者自己在集合外部维护一个计数器,然后依次读取每一个位置的元素,当读取到最后一个元素后,停止
    • 主要就是需要按元素的位置来读取元素
  • 2-迭代器遍历,Iterator:每一个具体实现的数据集合,一般都需要提供相应的Iterator
    • 相比于传统for循环,Iterator取缔了显式的遍历计数器
    • 所以基于顺序存储集合的Iterator可以直接按位置访问数据
    • 而基于链式存储集合的Iterator,正常的实现,都是需要保存当前遍历的位置
    • 然后根据当前位置来向前或者向后移动指针
  • 3-foreach循环遍历:根据反编译的字节码可以发现,foreach内部也是采用了Iterator的方式实现,只不过Java编译器帮我们生成了这些代码
  • 4-迭代器遍历:Enumeration:Enumeration 接口是Iterator迭代器的“古老版本”,从JDK 1.0开始,Enumeration接口就已经存在了(Iterator从JDK 1.2才出现)
  • Iterable和Iterator如何使用

  • Iterator和Iterable是两个接口
  • 前者代表的是迭代的方式,如next和hasNext方法就是需要在该接口中实现
  • 后者代表的是是否可以迭代,如果可以迭代,会返回Iterator接口,即返回迭代方式
  • 常见的使用方式一般是集合实现Iterable表明该集合可以遍历,同时选择Iterator或者自定义一个Iterator的实现类去选择遍历方式,如:

  • 为什么不把Iterable和Iterator合成一个使用

  • 1-通过Javadoc文档可以发现,Iterable和Iterator并不是同时出现的
  • Iterator于1.2就出现了,目的是为了代替Enumeration
  • 而Iterable则是1.5才出现的
  • 2-将是否可以迭代和迭代方式抽出来,更符合单一职责原则,如果抽出来,迭代方式就可以被多个可迭代的集合复用,更符合面向对象的特点
  • 哪些集合类是线程安全的

  • Vector:就比Arraylist多了个 synchronized(线程安全),因为效率较低,现在已经不太建议使用
  • hashTable:就比hashMap多了个synchronized(线程安全),不建议使用
  • ConcurrentHashMap:是Java5中支持高并发、高吞吐量的线程安全HashMap实现
    • 它由Segment数组结构和HashEntry数组结构组成
    • Segment数组在ConcurrentHashMap里扮演锁的角色,HashEntry则用于存储键-值对数据
    • 一个ConcurrentHashMap里包含一个Segment数组,Segment的结构和HashMap类似,是一种数组和链表结构
    • 一个Segment里包含一个HashEntry数组,每个HashEntry是一个链表结构的元素
    • 每个Segment守护着一个HashEntry数组里的元素,当对HashEntry数组的数据进行修改时,必须首先获得它对应的Segment锁(推荐使用)

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

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

相关文章

32位ARM M0+内核单片机 XL32F001简单介绍,Flash 24K,SRAM 3K

XL32F001 系列微控制器采用高性能的 32 位 ARM Cortex-M0内核,宽电压工作范围的 MCU。嵌入 24Kbytes Flash 和 3Kbytes SRAM 存储器,最高工作频率 24MHz。包含多种不同封装类型多款产品。芯片集成 I2C、SPI、USART 等通讯外设,1 路 12bit ADC…

十六、flex应用练习做淘宝按钮界面

目录: 目标小技巧实现最终代码 一、目标:我们要做一个手机版本的淘宝网,蓝色框住的按钮这部分。 二、 小技巧:如何在网页上看手机版本的页面 首先在网页上打开淘宝网,然后按F12,进入调试状态;&…

信号完整性分析基础知识之有损传输线、上升时间衰减和材料特性(一):为什么要关注损耗?

一个具有极快上升沿的信号输入到真实传输线中,在从传输线输出的时候上升时间会很长。例如,一个上升时间为50ps的信号,在经过一段36inch长,50Ohm传输线后,上升时间增加到1ns。上升时间的退化是由于传输线的损耗&#xf…

C#使用跨平台的PdfSharpCore开源库生成PDF文件

一、需求说明 在进行项目开发中,需要将C#程序的一些文本内容导出为PDF文件(能够根据文本自动分行分页),并且要求这个生成PDF文件的程序是可跨平台的;实现类似效果: 二、需求分析 ①将程序的文本内容导出为PDF文件; ②能够将文本内容自动分行分页【且可添加页眉、页脚、…

记录一次nginx日志偶现502报错排查

背景 之前的业务链路 负载均衡–>nginx–>cvm(业务后端node) 上云后链路 负载均衡–>nginx–>pod(业务后端node) 上云后nginx日志隔几个小时就出现一波502,查看nginx的日志有两个特征,就是re…

C# Linq 详解二

目录 概述 七、OrderBy 八、OrderByDescending 九、Skip 十、Take 十一、Any 十二、All 概述 语言集成查询 (LINQ) 是一系列直接将查询功能集成到 C# 语言的技术统称。 数据查询历来都表示为简单的字符串,没有编译时类型检查或 IntelliSense 支持。 此外&a…

matlab中画有重影的机器人运动过程【给另一个机器人设置透明度】

1、前言如题 2、参考连接如下 How to plot two moving robot in the same figure and change one of them transparency? - MATLAB Answers - MATLAB Central (mathworks.cn)3、代码:【找到figure中对应对象并设置属性】 % Create two instances of a…

【OJ比赛日历】快周末了,不来一场比赛吗? #07.15-07.21 #7场

CompHub[1] 实时聚合多平台的数据类(Kaggle、天池…)和OJ类(Leetcode、牛客…)比赛。本账号会推送最新的比赛消息,欢迎关注! 以下信息仅供参考,以比赛官网为准 目录 2023-07-15(周六) #3场比赛2023-07-16…

【多线程初阶】Thread类常见方法以及线程的状态

多线程初阶系列目录 持续更新中 1.第一次认识线程 2.Thread类常见方法以及线程的状态 … 文章目录 多线程初阶系列目录前言1. Thread 类及常见方法1.1 常见构造方法1.2 常见属性1.3 重要方法1.3.1 启动一个线程 ---- start()1.3.2 中断一个线程 ---- interrupt()1.3.3 等待一…

有PMP有没有必要换cspm?未来的发展前景如何?

最近 CSPM 证书很热门,CSPM 相关问题大家都很关心,今天本橘座就给大家全面解答一下 CSPM到底是何方神圣? 文章主要是解答下面几个常见问题,其他问题可以留言或者私信咨询我哦~ 一、什么是 CSPM证书?跟PMP是什么关系&a…

启动、关闭nacos

下载 进入官网 http://nacos.io/zh-cn/ 页面打开后,点击【前往Github】 进入Github页面,往下拖动,找到 latest stable release 选择当时最新的版本下载即可,这里选择.zip的文件下载 安装 Nacos 是免安装的,我们下…

备战秋招008(20230713)

文章目录 前言一、今天学习了什么?二、关于问题的答案1.集合2.JUC02、底层原理03、内存泄漏 总结 前言 提示:这里为每天自己的学习内容心情总结; Learn By Doing,Now or Never,Writing is organized thinking. 目前…

python - leetcode - 64. 最小路径和【经典题解 - 矩阵数组动态规划】

一. 题目:64. 最小路径和 描述: 给定一个包含非负整数的 m x n 网格 grid ,请找出一条从左上角到右下角的路径,使得路径上的数字总和为最小。 说明:每次只能向下或者向右移动一步。 示例 1: 输入&#…

【SpringBoot3】--02.Web开发

文章目录 SpringBoot3-Web开发0.WebMvcAutoConfiguration原理1.生效条件2.效果3.WebMvcConfigurer接口4. 静态资源规则源码5. EnableWebMvcConfiguration 源码6. 为什么容器中放一个WebMvcConfigurer就能配置底层行为7. WebMvcConfigurationSupport 1.Web场景1.1自动配置1.2默认…

51单片机-串口通信(串口向电脑发送信息电脑通过串口控制LED)

文章目录 前言一、串行通信口的功能以及串行通信口的结构及原理1.1 串行通信口的功能1.2 51单片机串口的结构 二、串行通信口的控制寄存器2.1 串行控制寄存器SCON2.2 电源控制寄存器PCON2.3 配置寄存器配置SCON寄存器配置PCON寄存器配置中断 2.4 实验单片机向pc发送数据PC向单片…

文心一言 VS 讯飞星火 VS chatgpt (58)-- 算法导论6.4 2题

文心一言 VS 讯飞星火 VS chatgpt (58)-- 算法导论6.4 2题 二、试分析在使用下列循环不变量时,HEAPSORT 的正确性:在算法的第 2~5行 for 循环每次迭代开始时,子数组 A[1…i]是一个包含了数组A[1…n]中第i小元素的最大…

[疑难杂症2023-005]dcmtk-movescu访问dcm4chee模拟PACS Server报错问题解析

本文由Markdown语法编辑器编辑完成。 1. 背景 由于要在医院上线一个服务,用来定时从医院的PACS Server上面拉取dicom图像并进行分发。因此,需要首先在公司的内网环境上进行开发,测试和验证。 目前比较流行和开源的PACS Server模拟是基于dc…

python 面向对象编程(2)

文章目录 前言封装多态类属性和实例属性定义以及访问类属性修改类属性实例属性 类方法静态方法 前言 前面我们介绍了 python 类和对象以及继承、私有权限,那么今天我们将来介绍 python面向对象 剩下的两大特性封装、多态,以及如何访问、修改类属性、类方…

机器学习李宏毅学习笔记37

文章目录 前言一、ChatGPT做的事情二、ChatGPT基础介绍三、ChatGPT带来的研究问题总结 前言 ChatGPT简单原理介绍 一、ChatGPT做的事情 Chatgpt以句子为输入,输出这个句子后面接的词汇的概率分布,给每一个可能的符号一个概率,根据这个分布进…

【雕爷学编程】Arduino动手做(160)---HLK-V20离线语音模块2

37款传感器与模块的提法,在网络上广泛流传,其实Arduino能够兼容的传感器模块肯定是不止37种的。鉴于本人手头积累了一些传感器和执行器模块,依照实践出真知(一定要动手做)的理念,以学习和交流为目的&#x…