java集合框架——List集合概述及ArrayList,LinkedList的区别

前言:

List系列集合是Collection集合中两个系列的其中一个,整理下笔记。打好基础,daydayup!

需要了解Collection的,可以看这篇java集合框架------Collection集合概述

List系列集合

List系列集合的特点为添加的元素有序,可重复,有索引。在继承了Collection方法的基础上,有很多索引相关的方法。

List系列常用方法

|---------------------------------|---------------------|
| 方法名称 | 说明 |
| void add(int index , E element) | 在此集合中的指定位置插入指定的元素 |
| E remove(int index) | 删除指定索引处的元素,返回被删除的元素 |
| E set(int index , E element) | 修改指定索引处的元素,返回被修改的元素 |
| E get(int index) | 返回指定索引处的元素 |

例:

List系列遍历方式

List的遍历方式有四种:1,for遍历;2,迭代器遍历;3,增强for遍历;4,lambda表达式遍历

例:

ArrayList

ArrayList是List系列中的一个,特点为元素有序,可重复,有索引。

曾经有写过,有需要可以看这篇java常用应用程序编程接口(API)------ArrayList概述及使用案例

LinkedList和ArrayList的区别

LinkedList的特点也是元素有序,可重复,有索引。但不太一样的是,ArrayList是基于数组实现的,而LinkedList是基于双链表进行实现的。

**基于数组实现的特点为:**1,根据索引查询数据快;2,删除效率低(删除数据需要把之后的向前移);3,添加效率低(需要把数据向后移动,再添加移动,同时添加数据需要进行扩容)

**基于双链表实现的特点为:**1,查询速度慢;2,增加/删除数据较快;3,对首尾元素增删改查的速度非常快。

**ArrayList适用的场景:**需要频繁用索引取数据的时候,或者数据量不是很大的时候。

**LinkedList适用的场景:**首位数据频繁更换,数据量大需要增删数据的时候,或不需要频繁使用索引取数据的时候

总结:

总之需要频繁用索引就用ArrayList,需要首位频繁增删改查就用LinkedList。整理结束,撒花!!!

相关推荐
故事和你914 分钟前
洛谷-算法2-2-常见优化技巧3
开发语言·数据结构·c++·算法·深度优先·动态规划·图论
foundbug9996 分钟前
MATLAB时频分析工具箱:基于FRFT的信号检测与参数估计
开发语言·matlab
DevilSeagull8 分钟前
Rust 方法语法:从定义到实践
开发语言·后端·rust
charlie1145141918 分钟前
通用GUI编程技术——图形渲染实战(三十七)——D3D11初始化与SwapChain:从零搭建GPU渲染框架
开发语言·c++·3d·图形渲染
陈天伟教授9 分钟前
GPT Image 2-城市海报
开发语言·人工智能·gpt·神经网络
原来是猿9 分钟前
线程安全的单例模式
linux·服务器·开发语言·单例模式·策略模式
charlie11451419110 分钟前
通用GUI编程技术——图形渲染实战(三十六)——Constant Buffer与数据传递:CPU-GPU通信通道
开发语言·c++·windows·c·图形渲染·win32
南境十里·墨染春水12 分钟前
C++笔记 STL lterator迭代器
开发语言·c++·笔记
学习使我健康13 分钟前
Android 广播介绍详情
android·开发语言·kotlin
普修罗双战士13 分钟前
高效使用 Git:从入门到精通的实战指南
java·git