List与Set、数组与ArrayList、ArrayList与LinkedList的区别

news/2024/12/12 5:23:24/

List 与 Set 的区别:

ListSet
重复允许重复的对象(多个null也可以)不允许重复的对象(null也只能有一个)
有序性有序的。 保持了每个元素的插入顺序。即输出顺序就是输入顺序。

有序和无序都有。

HashSet:无法保证每个元素的存储顺序。 LinkedHashSet:按插入顺序存放。

数组与 ArrayList 的区别:

相同点:

        1. 都具有索引(index):可以通过 index 来直接获取和修改任意项;

        2. 它们所创建的对象都放在堆中;

        3. 都能够对自身进行枚举(因为都实现了 IEnumerable 接口);

不同点:

数组(Array)ArrayList
数据类型可以是基本类型或对象类型。只能是对象类型。
大小大小是固定的,Array对象的初始化必须指定大小大小是动态的
数据存放连续存放(在内存中,数组的元素是按照顺序依次存储在一块连续的内存空间中的。这种连续存储的方式使得数组在随机访问时效率很高,因为可以通过计算偏移量直接定位到元素的内存位置。例如,对于一个int类型的数组,每个元素占用 4 个字节,如果知道数组的起始地址和元素的索引,就可以通过简单的乘法和加法运算来计算出元素的内存地址。)对象的引用是连续的,但对象本身在内存中的位置不一定连续。(ArrayList 内部维护的是一个对象引用数组,这些引用在内存中是连续存放的。但是,这些引用所指向的实际对象(如String对象或其他自定义对象)本身在内存中的位置是由 Java 虚拟机的内存管理系统根据内存的使用情况动态分配的,不一定是连续的。这种存储方式在插入和删除元素时相对灵活,但在一定程度上可能会影响访问效率。
插入与删除不能够添加和删除其中的项可以在任意位置插入和删除项。

访问

效率

ArrayList 与 LinkedList 的区别:

相同点:

        1. 都是线程不安全的;

        2. 都是按照存入的顺序取出;

不同点:

ArrayListLinkedList
实现方式基于数组。基于链表。
随机访问支持随机访问。(实现了RandomAccess 接口)不支持随机访问。
插入效率插入效率比较低(需要扩容时效率会变低)。插入效率比较高(删除不一定高)。
使用场景随机访问的场景。插入很频繁的场景 用作:栈、队列或双向队列

http://www.ppmy.cn/news/1554405.html

相关文章

can协议中的网络管理

为什么需要网络管理? 网络管理最终要实现的是车上的ECU能够协同睡眠以及唤醒,也就是说网络管理最重要的一点是要保证车上的ECU能够协同唤醒和休眠。那么假如车上的ECU都处于睡眠模式,网络上都没有报文,你咋实现唤醒呢,…

前端流式播放TTS语音:技术细节与实现

摘要 本文将介绍如何在前端实现流式播放文本到语音(TTS)的语音,并加入确保语音播放不重叠的改进方案。我们将探讨使用Web Audio API和WebSocket进行实时语音播放的技术细节,并提供相应的代码示例。 一、引言 在之前的讨论中&am…

基于单片机指纹识别电子寄存柜设计

摘要: 触摸屏信息显示、电控锁继电器控制、计算机终端管理控制等部分。相比于条码式寄存柜,具有操作简单,维护方便,性能可靠等诸多优 本文研究一种基于单片机的指纹识别电子寄存柜控制系统。主控芯片采用 STC12C5A60S2 增强型单片机,系统包括指纹识别、LCD点。此外,设计…

AndroidStudio-常见界面控件

一、Button package com.example.review01import androidx.appcompat.app.AppCompatActivity import android.os.Bundle import android.widget.Button import android.widget.TextViewclass Review01Activity : AppCompatActivity() {override fun onCreate(savedInstanceStat…

顶会新宠!KAN-LSTM完美融合新方案

2024深度学习发论文&模型涨点之——KANLSTM KAN-LSTM混合预测模型是一种结合了自注意力机制(KAN, Key-attention network)和长短时记忆网络(LSTM)的深度学习模型,主要用于序列数据的预测任务,如时间序…

Flutter踩坑记录(一)debug运行生成的项目,不能手动点击运行

问题 IOS14设备,切后台划掉,二次启动崩溃。 原因 IOS14以上 flutter 不支持debugger模式下的二次启动 。 要二次启动需要以release方式编译工程安装至手机。 操作步骤 清理项目:在命令行中运行flutter clean来清理之前的构建文件。重新构…

uni-app登录界面样式

非常简洁的登录、注册界面模板&#xff0c;使用uni-app编写&#xff0c;直接复制粘贴即可&#xff0c;无任何引用&#xff0c;全部公开。 废话不多说&#xff0c;代码如下&#xff1a; login.vue文件 <template><view class"screen"><view class"…

Unity 使用LineRenderer制作模拟2d绳子

效果展示&#xff1a; 实现如下&#xff1a; 首先&#xff0c;直接上代码&#xff1a; using System.Collections; using System.Collections.Generic; using UnityEngine;public class LineFourRender : MonoBehaviour {public Transform StartNode;public Transform MidNod…