ArrayList与LinkLIst
ArrayList
在Java中,ArrayList是java.util包中的一个类,它实现了List接口,是一个动态数组,可以根据需要自动增长或缩小。下面是ArrayList的一些基本特性以及其底层原理的简要讲解:
ArrayList基本特性:
-
动态数组:
ArrayList是一个动态数组,它可以根据需要自动调整大小。 -
允许重复元素:
ArrayList允许存储相同的元素,可以包含重复的值。 -
随机访问: 通过索引,可以以常数时间复杂度进行元素的访问,这是由于底层是数组实现。
-
不同步:
ArrayList不是线程安全的,如果多个线程同时访问一个ArrayList实例,而至少有一个线程修改了列表结构,那么它必须保持外部同步。
API
boolean add(E element): | 将指定的元素添加到列表的末尾。 |
void add(int index, E element): | 在指定的位置插入指定的元素。 |
E get(int index) | 回列表中指定位置的元素。 |
int size(): | 返回列表中的元素数。 |
boolean remove(Object o) | 从列表中删除指定的元素(如果存在) |
E remove(int index) | 删除列表中指定位置的元素。 |
boolean contains(Object o) | 如果列表包含指定的元素,则返回 true。 |
void clear(): | 从列表中删除所有元素。 |
boolean isEmpty(): | 如果列表不包含元素,则返回 true。 |
ArrayList底层原理:
-
基于数组:
ArrayList的底层是一个数组。当你创建一个ArrayList时,它会初始化一个数组来保存元素。初始时,默认大小是0的数组。当添加第一个元素的时候,底层会创建一个长度为10的数组 -
自动扩容: 当元素数量超过当前数组容量时,
ArrayList会创建一个新的数组,将元素复制到新数组中,并更新引用。通常,新数组的大小是原数组的1.5倍。如果一次添加多个元素1.5倍放不下,则新建数组长度以实际长度为准 -
容量增长:
ArrayList的容量增长不是按需一次性增长的,而是按照一定的策略进行递增。这样可以减少频繁扩容的开销。 -
元素的添加和删除: 在数组中,添加和删除元素可能涉及到移动其他元素,这可能导致性能开销。在某些情况下,特别是在大量操作的情况下,可能会考虑使用
LinkedList,因为在链表中添加和删除元素的开销较小。
// 示例代码
import java.util.ArrayList;public class ArrayListExample {public static void main(String[] args) {// 创建ArrayListArrayList<String> arrayList = new ArrayList<>();// 添加元素arrayList.add("Java");arrayList.add("Python");arrayList.add("C++");// 访问元素System.out.println("First element: " + arrayList.get(0));// 删除元素arrayList.remove("Python");// 打印所有元素System.out.println("All elements: " + arrayList);}
}

总体而言,ArrayList是一个灵活且性能良好的集合类,适用于大多数元素的存储和检索场景。
LinkList
LinkedList是Java集合框架中的另一种实现List接口的类,它基于链表数据结构。相比于ArrayList,LinkedList在一些操作上有不同的性能特点。
LinkedList的基本特性:
-
基于链表:
LinkedList使用双向链表实现,每个元素都包含一个指向前一个元素和一个指向后一个元素的引用。这使得在链表中插入和删除元素更为高效,因为不需要移动其他元素。 -
不适合随机访问: 由于是链表结构,
LinkedList在随机访问元素时效率较低。访问某个特定位置的元素需要从头或尾开始遍历链表。 -
元素添加和删除高效: 在链表中插入和删除元素的操作相对较快,因为只需要更新相邻元素的引用,而不需要像数组一样移动大量元素。
-
不同步:
LinkedList也是非线程安全的,如果需要在多线程环境中使用,需要进行外部同步。
API
boolean add(E element) | 将指定的元素添加到列表的末尾。 |
void add(int index, E element) | 在指定的位置插入指定的元素 |
E get(int index): | 返回列表中指定位置的元素 |
E getFirst() | 返回列表中的第一个元素 |
E getLast(): | 返回列表中的最后一个元素。 |
boolean remove(Object o) | 从列表中删除指定的元素(如果存在) |
E remove(int index): | 删除列表中指定位置的元素。 |
E removeFirst(): | 删除并返回列表的第一个元素 |
E removeLast() | 删除并返回列表的最后一个元素 |
boolean contains(Object o) | 如果列表包含指定的元素,则返回 true。 |
void clear() | 从列表中删除所有元素 |
E set(int index, E element): | 用指定的元素替换列表中指定位置的元素。 |
boolean isEmpty(): | 如果列表不包含元素,则返回 true。 |
int indexOf(Object o) | 返回列表中第一次出现的指定元素的索引;如果列表不包含此元素,则返回 |
boolean offer(E e) | 将指定的元素添加到列表的末尾(队尾)。 |
E poll(): | 检索并删除列表的头部(队首)元素。 |
void push(E e): | 将元素推入列表所表示的堆栈(在列表的头部)。 |
E pop(): | 从列表所表示的堆栈中弹出第一个元素。 |
Object[] toArray(): | 返回包含列表中所有元素的数组。 |
示例代码:
import java.util.LinkedList;public class LinkedListExample {public static void main(String[] args) {// 创建LinkedListLinkedList<String> linkedList = new LinkedList<>();// 添加元素linkedList.add("Java");linkedList.add("Python");linkedList.add("C++");// 访问元素System.out.println("First element: " + linkedList.getFirst());// 删除元素linkedList.remove("Python");// 打印所有元素System.out.println("All elements: " + linkedList);}
}
适用场景:
- 当需要频繁执行插入和删除操作时,特别是在列表的中间位置。
- 当对列表进行迭代操作而不是随机访问时。
总体而言,LinkedList和ArrayList各有优势,选择取决于具体的使用场景。ArrayList适用于随机访问和大量元素的存储,而LinkedList适用于频繁插入和删除的场景。
相关文章:
ArrayList与LinkLIst
ArrayList 在Java中,ArrayList是java.util包中的一个类,它实现了List接口,是一个动态数组,可以根据需要自动增长或缩小。下面是ArrayList的一些基本特性以及其底层原理的简要讲解: ArrayList基本特性: 动…...
位运算(、|、^、~、>>、<<)
分类 编程技术 1.位运算概述 从现代计算机中所有的数据二进制的形式存储在设备中。即 0、1 两种状态,计算机对二进制数据进行的运算(、-、*、/)都是叫位运算,即将符号位共同参与运算的运算。 口说无凭,举一个简单的例子来看下 CPU 是如何进…...
Centos7部署SVN
文章目录 (1)SVN概述(2)SVN与Samba共享(3)安装SVN(4)SVN搭建实例(5)pc连接svn服务器(6)svn图标所代表含义 (1)…...
Vue中this.$nextTick的执行时机
一、Vue中this.$nextTick的执行时机,整体可分为两种情况: 第一种:下一次 Dom 更新之后执行(即等待DOM更新结束之后,执行nextTick的延迟回调函数); 第二种:页面挂载后 (m…...
Unity中的ShaderToy
文章目录 前言一、ShaderToy网站二、ShaderToy基本框架1、我们可以在ShaderToy网站中,这样看用到的GLSL文档2、void mainImage 是我们的程序入口,类似于片断着色器3、fragColor作为输出变量,为屏幕每一像素的颜色,alpha一般赋值为…...
2 使用postman进行接口测试
上一篇:1 接口测试介绍-CSDN博客 拿到开发提供的接口文档后,结合需求文档开始做接口测试用例设计,下面用最常见也最简单的注册功能介绍整个流程。 说明:以演示接口测试流程为主,不对演示功能做详细的测试,…...
【数据库设计和SQL基础语法】--查询数据--聚合函数
一、聚合函数概述 1.1 定义 聚合函数是一类在数据库中用于对多个行进行计算并返回单个结果的函数。它们能够对数据进行汇总、统计和计算,常用于提取有关数据集的摘要信息。聚合函数在 SQL 查询中广泛应用,包括统计总数、平均值、最大值、最小值等。 1…...
Module ‘app‘: platform ‘android-33‘ not found.
目录 一、报错信息 二、解决方法 一、报错信息 Module app: platform android-33 not found. 检查你的应用程序的build.gradle文件中的targetSdkVersion和compileSdkVersion是否正确设置为已安装的Android SDK版本。 确保你的Android Studio已正确安装并配置了所需的Android …...
MySQL按序批量操作大量数据
MySQL按序批量操作大量数据(Java、springboot、mybatisplus、ElasticSearch) 以同步全量MySQL数据到ElasticSearch为例。 核心代码 业务逻辑: public boolean syncToElasticsearch() {log.info("Starting data synchronization to El…...
strict-origin-when-cross-origin
严格限制同源策略 (1)允许服务器的同源IP地址访问 (2)允许Referer --- 后端服务器要配置...
【置顶】 本博博文汇总
文章目录 前言音视频ijkplayer源码分析FFmpeg、音视频协议Andriod系统音视频框架C、C Android&Java源码分析、绘制、渲染Dalvik、Art虚拟机Java并发 计算机基础操作系统计算机网络设计模式、数据结构、算法 前言 23年底了,想来也工作十年,也一直在c…...
react.js源码二
三、调度Scheduler scheduling(调度)是fiber reconciliation的一个过程,主要决定应该在何时做什么?在stack reconciler中,reconciliation是“一气呵成”,对于函数来说,这没什么问题,因为我们只想要函数的运行结果,但对于UI来说还需要考虑以下问题: 并不是所有的state更…...
如何学习英语
前言 首先写一些自己的感言吧,其实从大学的时候就在不断地听英语,学英语,但是到毕业十几年后,英语一直没起到什么作用,当然最有作用的时候就是几次英语面试吧。 工作之后有一段学习英语的经历,当时花费了…...
robot测试自动化
一. 安装 黑羽robot 首先确保你电脑上安装好了 Python 3.7 或者 3.8 版本的解释器 hyrobot 使用说明1 | 白月黑羽 安装RF 黑羽robot基于Robot Framework ,所以必须先安装RobotFramework 直接执行如下Pip命令即可: pip install robotframework...
Linux---重定向命令
1. 重定向命令的介绍 重定向也称为输出重定向,把在终端执行命令的结果保存到目标文件。 2. 重定向命令的使用 命令说明>如果文件存在会覆盖原有文件内容,相当于文件操作中的‘w’模式>>如果文件存在会追加写入文件末尾,相当于文件…...
小区生活污水处理需要哪些设备和工艺
在小区生活中,污水处理是一个非常重要的环节,它关乎到环境的保护和居民的生活质量。因此,了解小区生活污水处理所需要的设备和工艺是至关重要的。 首先,在小区生活污水处理中,需要用到的设备包括污水收集系统、初级沉淀…...
【高性能计算】Cpp + Eigen + Intel MKL + 函数写成传引用
CUDA加速原理:CUDA编程学习:自定义Pytorch+cpp/cuda extension 高质量C++进阶[2]:如何让线性代数加速1000倍? 【gcc, cmake, eigen, opencv,ubuntu】三.eigen和mkl安装和使用 Linux下MKL库的安装部署与使用,并利用cmake编译器调用MKL库去提升eigen库的计算速度 Eigen库…...
【教学类-05-02】20231216 (比大小> <=)X-Y之间的比大小88题(补全88格子,有空格分割提示)
作品展示: 背景需求: 1、以前做过一份比大小的题目 【教学类-05-01】20211018 Python VSC 大班 数字比大小(> <)_vsc比较3位数大小-CSDN博客文章浏览阅读674次。【教学类-05-01】20211018 Python VSC 大班…...
【Spark精讲】Spark与MapReduce对比
目录 对比总结 MapReduce流程 编辑 MapTask流程 ReduceTask流程 MapReduce原理 阶段划分 Map shuffle Partition Collector Sort Spill Merge Reduce shuffle Copy Merge Sort 对比总结 Map端读取文件:都是需要通过split概念来进行逻辑切片&…...
SQL错题集3
1.薪水第二多的员工的emp_no以及其对应的薪水salary limit a,b 其中a表示查询数据的起始位置,b表示返回的数量。 (MySQL数据库中的记录是从0开始的) 注意从0开始 2.员工编号emp_no为10001其自入职以来的薪水salary涨幅值growth 聚合函数不能…...
新手装 Node.js 总踩坑,这份保姆级教程帮你一次搞定(附镜像加速+版本切换)
🔥个人主页:北极的代码(欢迎来访) 🎬作者简介:java后端学习者 ❄️个人专栏:苍穹外卖日记,SSM框架深入,JavaWeb ✨命运的结局尽可永在,不屈的挑战却不可须臾或…...
DSI3协议CRM模式波形全解析:从曼彻斯特编码到电流响应(Elmos 521.42实测)
DSI3协议CRM模式波形全解析:从曼彻斯特编码到电流响应(Elmos 521.42实测) 在汽车电子与工业传感器领域,DSI3(Distributed System Interface 3)协议凭借其高可靠性、抗干扰能力和多节点同步特性,…...
Kafka 核心组件及其作用(全解)
Kafka 是一个分布式、高吞吐量、高可用的消息队列与流处理平台,其架构设计围绕"水平扩展、持久化存储、低延迟"三大核心目标展开。以下是 Kafka 所有核心组件的详细解析,包含原理、作用、关键特性和生产级最佳实践。 一、Kafka 整体架构概览 K…...
Design - 一些免费图标网站
一些有用的工具网站;除了直接AI生成外,仍然有些有用的Icon免费网站,比较适合游戏的有:1. icons8.com最适合综合型游戏项目图标、插画、UI 资源比较全风格统一,适合游戏界面、按钮、功能图标可在线调整颜色和尺寸&#…...
构建时内容处理与类型安全:Content Collections 在现代前端项目中的应用
1. 项目概述:告别手动解析,拥抱类型安全的内容管理如果你和我一样,长期在 Next.js、SvelteKit 这类现代前端框架里折腾内容驱动的网站,比如博客、文档站或者产品页面,那你肯定对下面这个场景不陌生:项目根目…...
基于Roslyn为AI智能体生成C#代码地图:原理、实现与优化
1. 项目概述:为AI智能体绘制C#代码地图在AI智能体(Agent)技术日益成熟的今天,如何让这些“数字大脑”高效、准确地理解和操作复杂的代码库,成为了一个极具挑战性的工程问题。想象一下,你有一个精通C#的AI助…...
避坑指南:树莓派USB摄像头识别出两个video设备怎么办?实测罗技免驱摄像头
树莓派USB摄像头双设备节点问题全解析:从原理到实战 当你兴冲冲地将罗技C310这样的免驱USB摄像头插入树莓派,准备开始你的计算机视觉项目时,却在终端输入ls /dev/video*后发现了video0和video1两个设备节点——这与大多数教程中描述的单一设备…...
如何用magnetW实现23个磁力站点的聚合搜索?一站式桌面应用完全指南
如何用magnetW实现23个磁力站点的聚合搜索?一站式桌面应用完全指南 【免费下载链接】magnetW [已失效,不再维护] 项目地址: https://gitcode.com/gh_mirrors/ma/magnetW magnetW是一款基于Electron框架开发的跨平台磁力链接聚合搜索工具ÿ…...
LLM 应用开发:RAG 与知识增强
LLM 应用开发:RAG 与知识增强 1. 技术分析 1.1 RAG 概述 RAG (Retrieval-Augmented Generation) 将检索与生成结合: RAG 架构知识库检索 → 生成回答流程:1. 问题向量化2. 检索相关文档3. 构建提示词4. LLM 生成回答1.2 RAG 组件 组件功能常用工具知识库…...
从Token泛滥到 Token 极度节俭:2026程序员必须掌握的推理成本优化指南
最近三个月,我身边越来越多的技术团队开始感受到一种压力。不是模型不够强,是账单涨得太快。我们组上个月刚把几个核心业务切到某新模型,效果确实好,但推理成本翻了4倍。老板问了一句:这钱能不能省一半?会议…...
