Java的集合类

一、集合(Collection和Map)

(一)List集合(有序,可重复,存取顺序一致):

1.概述:

有序的collection,此接口的用户可以对列表中每个元素的插入位置进行精确的控制。用户可以根据元素的整数索引(在列表中的位置)访问元素,并搜索列表的元素,且允许重复的元素与set不同

2.List集合的特有功能:

(1)添加功能:
void add(int index,object element);在指定位置添加元素
(2)获取功能:
object get(int index);获取指定位置的元素
(3)列表迭代器:
listIterator ();List集合特有的迭代器
(4)删除功能:
object remove(int index);根据索引位置删除元素,返回被删除的元素
(5)修改功能:
object set(int index,object element);根据索引位置修改元素,返回被修改的元素
(6)注意:
列表迭代器的特有功能:
object previous();获取上一个元素
boolean hasPrevious();判断是否有元素
(7)迭代器遍历元素的时候,通过集合是不能修改元素的吗?
1.迭代器迭代元素,迭代器修改元素(元素是跟在刚才迭代的元素后面的)
2.集合遍历元素,集合修改元素(元素都是在最后添加的)

3.List item

List各个子类的特点:
(1)ArrayList:底层数据结构是数组,查询快,增删慢,线程不安全但效率高,适合遍历
(2)Vector:底层数据结构是数组,查询快,增删慢,线程安全但效率低
(3)LinkedList:底层数据结构是链表,查询慢,增删快,线程不安全但效率高,不适合遍历,适合插入删除

4.Vector的特有功能:

5、LinkedList的特有功能:

(1)添加功能:
public void addElement(object obj);-----add();
(2)获取功能:
public Object elementAt(int index);-----get();
public Enumeration elements();-----Iterator iterator();
public boolean hasMoreElements();-----hasNext();
public Object nextElement();-----next();

(二)set集合(无序,唯一,存取速度不一致):

1.HashSet的无重复原则:

是equals和hashcode方法起着作用,默认比较两个对象的地址,若想要用无重复需要重写equals和hashcode的方法

2.TreeSet:

TreeSet是按Unicode排序,且底层是二叉树结构(红黑树是一中自平衡的二叉树)
若想要用无重复需要重写compareTo方法,返回值int 负数在前正数在后
若想把自己的类存入TreeSet中,需要实现Comparable接口

(三)Map集合:

1.概述:

(1) 将键映射到值的对象
(2) 一个映射不能包含重复的键
(3) 每个键最多只能映射到一个值

2.Map集合的功能:

(1)添加功能: 
V put(K key,V value);添加元素
(2)删除功能: 
void clear();移除所有键值对元素
V remove(Object key);根据键删除键值对元素,并把值返回
(3)判断功能: 
boolean contains Key(Object key);判断集合是否包含指定的键值
boolean containsValue(Object value);判断集合是否包含指定的值
boolean isEmpty();判断集合是否为空 
(4)获取功能:
Set < map .empty< K,V > > entrySet();返回键值对对象的集合
V get (Object key);根据建获取值
Set < K > keySet();获取集合中所有的键值
Collection< V > values();获取集合中所有值的集合
(5)长度功能:
 int size();返回集合中的键值对的对数

3.Map各个子类的特点:

(1)HashMap:是基于哈希表的Map接口实现的,哈希表的作用是用来保证键的唯一性
(2)LinkedHashMap:是Map接口的哈希表和链连接列表实现,具有可预知的迭代顺序
(3)TreeMap:是基于红黑树的Map接口的实现
(4)HashMap和HashTable区别:
HashMap是线程不安全,效率高,允许null键和null值
HashTable是线程安全,效率低,不允许null键和null值

二、Collections

1.概述:

Collections是针对集合进行操作的工具类,都是静态方法

2.collection和collections区别:
Collection是单列集合的顶层接口,有子接口List和Set
Collections是真的集合操作的工具类,又对集合进行排序和二分查找的方法

3.collections的方法:
public static < T > void sort(List< T > list);排序,默认情况下为自然排序
public static < T > int binarySearch(List< ? > list,T key);二分查找
public static < T > Tmax(Collection< ?> col());最大值
public static void reverse(List< ? > list);反转
public static void shuffle(List< ?> list);随即置换

三、总结

(1)List(有序,可重复)

1.ArrayList:底层数据结构是数组,查询快,增删慢,线程不安全但效率高,适合遍历
2.Vector:底层数据结构是数组,查询快,增删慢,线程安全但效率低
3. LinkedList:底层数据结构是链表,查询慢,增删快,线程不安全但效率高,不适合遍历,适合插入删除

(2)Set(无序,唯一)

1.HashSet:
底层数据结构是哈希表,哈希表依赖的两个方法是hashcode()和equals()
执行顺序是:
首先判断hashcode()值是否相同
是,继续执行equals(),看其是否相同
ture:说明元素重复,不需添加
false:直接添加到集合中
否,直接添加到集合中

2.LinkedSet:
底层数据结构由链表和哈希表组成
由链表保证元素有序,由哈希表保证元素唯一

3.TreeSet:
TreeSet是按Unicode排序,且底层是二叉树结构(红黑树是一中自平衡的二叉树)
如何保证元素的唯一性?
根据比较的返回值是否为0来决定
如何保证元素的排序?
自然排序(圆具备比较性)让元素所属的类实现Coparable接口
比较器排序(集合具备比较性)让集合接受一个Comparable的实现类对象

(3)Map(双列集合,无序,可重复)

1.HashMap:
底层数据结构是哈希表,线程不安全,哈希表依赖的两个方法是hashcode()和equals()
执行顺序是:
首先判断hashcode()值是否相同
是,继续执行equals(),看其是否相同
ture:说明元素重复,不需添加
false:直接添加到集合中
否,直接添加到集合中

2.LinkeeHashMap:
底层数据结构由链表和哈希表组成
由链表保证元素有序,由哈希表保证元素唯一

3.HashTable:
底层数据结构是哈希表,线程安全,效率低,哈希表依赖的两个方法是hashcode()和equals()
执行顺序是:
首先判断hashcode()值是否相同
是,继续执行equals(),看其是否相同
ture:说明元素重复,不需添加
false:直接添加到集合中
否,直接添加到集合中

4.TreeMap:

TreeMap底层数据结构是红黑树(红黑树是一中自平衡的二叉树)
如何保证元素的唯一性?
根据比较的返回值是否为0来决定
如何保证元素的排序?
自然排序(圆具备比较性)让元素所属的类实现Coparable接口
比较器排序(集合具备比较性)让集合接受一个Comparable的实现类对象

(4)适用范围:

List适用于顺序存储,ArrayList适用于遍历,LinkedList适用于插入删除
Set适用于自动去掉重复元素(Hash性能高,Tree则可自动排序)
Map< k,v > 通过唯一的k来寻找v则用Map

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

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

相关文章

onnx 格式模型可视化工具

onnx 格式模型可视化工具 0. 引言1. 可视化工具2. 安装 Netron: Viewer for ONNX models 0. 引言 ONNX 是一种开放格式&#xff0c;用于表示机器学习模型。ONNX 定义了一组通用运算符&#xff08;机器学习和深度学习模型的构建基块&#xff09;和通用文件格式&#xff0c;使 A…

100天精通Python(实用脚本篇)——第118天:基于selenium和ddddocr库实现反反爬策略之验证码识别

文章目录 专栏导读一、前言二、ddddocr库使用说明1. 介绍2. 算法步骤3. 安装4. 参数说明5. 纯数字验证码识别6. 纯英文验证码识别7. 英文数字验证码识别8. 带干扰的验证码识别 三、验证码识别登录代码实战1. 输入账号密码2. 下载验证码3. 识别验证码并登录 书籍推荐 专栏导读 …

SAR ADC教程系列5——FFT频谱泄露以及相干采样

频谱泄露的出现以及如何规避&#xff1f; 为什么要相干采样&#xff1f; 1.分析ADC输出信号的频谱工具&#xff1a;DFT&#xff08;Discrete Fourier Transform) 重点&#xff1a;DFT相邻频谱频率间隔为fs/N 如何规避频谱泄露&#xff1f; 对于DFT&#xff0c;它对于接收到的信…

前端项目部署后,如何提示用户版本更新

目录 前言解决方案1、public目录下新建manifest.json2、写入当前时间戳到manifest.json3、检查版本更新4、woker线程5、入口文件引入 可能出现的问题 前言 项目部署上线后&#xff0c;特别是网页项目&#xff0c;提示正在操作系统的用户去更新版本非常 important。一般我们都会…

osg执行opengl4.3的shader报错

运行案例&#xff1a;运行这篇博客的opengl4.3的例子&#xff0c;OSG使用GLSL各个版本例子&#xff0c;报如下错误&#xff1a; Warning: detected OpenGL error invalid operation at after pcp->apply(Unfiorm&) in GLObjectsVisitor::apply(osg::StateSet& stat…

C++ 笛卡尔树

目录 一、性质二、构建笛卡尔树三、应用四、源码 一、性质 堆性质&#xff1a; 笛卡尔树是一种满足堆性质的树。每个节点包含两个值&#xff1a;键值&#xff08;key&#xff09;和优先级值&#xff08;priority&#xff09;。在笛卡尔树中&#xff0c;根节点的优先级值最大&am…

Prompt提示工程上手指南:基础原理及实践(三)-Prompt个性知识库引导

前言 Prompt系列的第二期文章已经将所有的Prompt工程主流策略讲解完毕&#xff0c;共涉及到六种Prompt类别模型以及具体生产内容详解。再结合系列第一篇文章具体对Prompt工程的详细介绍&#xff0c;也就可以达到Prompt工程师的初步入门&#xff0c;现在如果掌握了这些基础技能…

电话机器人系统搭建安装教程步骤

电话机器人系统搭建安装的步骤可能会因具体的产品和服务提供商有所不同&#xff0c;但一般来说&#xff0c;以下是一些基本的步骤&#xff1a; 1. 准备硬件和软件环境 首先&#xff0c;你需要准备合适的硬件和软件环境。这可能包括一台或多台计算机&#xff0c;以及相应的操作…

价值学习和策略学习的区别

价值学习&#xff08;Value Learning&#xff09;和策略学习&#xff08;Policy Learning&#xff09;是强化学习中的两种主要方法&#xff0c;它们在如何学习和做出决策上有根本的区别。 价值学习&#xff1a; 价值学习的核心在于评估每个状态&#xff08;或状态和动作的组合&…

在pharmit里匹配药效团

我把400个无活性的小分子&#xff08;decoys&#xff09;提交到pharmit里。 命名为decoyset00~decoyset08&#xff0c;查找时&#xff0c;按这个找。 1、导入药效团配体&#xff1a; 进入药效团筛选界面&#xff1a; 导入代表药效团模型的活性肽构象&#xff1a; 2、选择预先…

MATLAB环境下基于可调Q因子小波变换的滚动轴承故障诊断(MATLAB R2021B)

小波变换是一种时频局域化方法&#xff0c;它的窗口面积固定但形状可以发生改变&#xff08;时间窗与频率窗均可变化&#xff09;。小波变换在时间域与频率域都能够表示信号的局部特征&#xff0c;并具有多分辨率分析的特点&#xff0c;是机械故障诊断中常用的方法。小波变换故…

【C++】手撕红黑树

> 作者简介&#xff1a;დ旧言~&#xff0c;目前大二&#xff0c;现在学习Java&#xff0c;c&#xff0c;c&#xff0c;Python等 > 座右铭&#xff1a;松树千年终是朽&#xff0c;槿花一日自为荣。 > 目标&#xff1a;能直接手撕红黑树。 > 毒鸡汤&#xff1a;行到…

计算机设计大赛 题目:基于深度学习卷积神经网络的花卉识别 - 深度学习 机器视觉

文章目录 0 前言1 项目背景2 花卉识别的基本原理3 算法实现3.1 预处理3.2 特征提取和选择3.3 分类器设计和决策3.4 卷积神经网络基本原理 4 算法实现4.1 花卉图像数据4.2 模块组成 5 项目执行结果6 最后 0 前言 &#x1f525; 优质竞赛项目系列&#xff0c;今天要分享的是 基…

OLAP与数据仓库和数据湖

OLAP与数据仓库和数据湖 本文阐述了OLAP、数据仓库和数据湖方面的基础知识以及相关论文。同时记录了我如何通过ChatGPT以及类似产品&#xff08;通义千问、文心一言&#xff09;来学习知识的。通过这个过程让我对于用AI科技提升学习和工作效率有了实践经验和切身感受。 预热 …

vue2使用axios封装请求数据,教会你封装,简单易懂,轻松学会axios封装请求数据 看一眼就会 手把手教会

前端vue2中axios封装请求数据&#xff0c;教会你封装教会你请求数据 简单易懂&#xff0c;轻松学会axios封装请求数据 看一眼就会 手把手教会 1、在完成下面的步骤之前&#xff0c;先脚手架创建vue项目&#xff0c;然后再vue项目当中&#xff0c;首先先创建一个文件夹utils&…

VSCode+python单步调试库代码

VSCodepython单步调试库代码 随着VSCode版本迭代更新&#xff0c;在最新的1.87.x中&#xff0c;使用Python Debugger扩展进行调试时&#xff0c;扩展的justMyCode默认属性为true&#xff0c;不会进入库中的代码。这对debug而言不太方便&#xff0c;因此需要手动设置一下&#…

蓝桥杯--平均

在编程竞赛&#xff0c;尤其是参与蓝桥杯的过程中&#xff0c;遇到各种问题需求是家常便饭。最近&#xff0c;我遇到了一个非常有趣且颇具挑战性的算法问题。问题描述如下&#xff1a;对于一个长度为n的数组&#xff08;n是10的倍数&#xff09;&#xff0c;数组中的每个元素均…

leetcode 3080

leetcode 3080 题目 例子 思路 创建数组&#xff0c;记录nums 的值 对应的id, 按照大小排序。 代码实现 class Solution { public:vector<long long> unmarkedSumArray(vector<int>& nums, vector<vector<int>>& queries) {vector<long…

hadoop伪分布式环境搭建详解

&#xff08;操作系统是centos7&#xff09; 1.更改主机名&#xff0c;设置与ip 的映射关系 hostname //查看主机名 vim /etc/hostname //将里面的主机名更改为master vim /etc/hosts //将127.0.0.1后面的主机名更改为master&#xff0c;在后面加入一行IP地址与主机名之间的…

Android VINF和兼容性矩阵

周末搞这玩意欲仙欲死&#xff0c;没办法只有看看。VINTF是供应商接口对象&#xff08;VINTF 对象&#xff09;&#xff0c;准确的说&#xff0c;这个是属于兼容性矩阵概念。。。有点想起了以前看过的一个电影&#xff0c;异次元杀阵。。。 1 基础 这个是谷歌官方的图。 本质…