Java数据类型 Arrays VS ArraysList VS LikedList 解析

在学习Java过程中,在刷题时总是搞不清楚这三种数据结构的区别,打算写篇文章记录一下

[Arrays VS ArrayList](#Arrays VS ArrayList)

[ArrayList VS LinkedList](#ArrayList VS LinkedList)

总结

Arrays VS ArrayList

Arrays ArrayList
类型 Java的基本数据类型 Java集合框架中的一个类,实现了List接口
存储内容 基本数据类型+对象引用 对象引用
可变性 数组长度创建后不可变 长度可变
适用场景 查询元素会比较快,直接通过索引访问 添加或者删除元素,尤其是在末尾操作
提供方法 操作有限, 排序,访问,修改 方法更多,添加,删除,迭代等

ArrayList VS LinkedList

ArrayList LinkedList
实现方式 基于动态数组实现 基于双向链表实现
性能 通过索引直接访问,随机访问更快 基于链表实现,插入和删除会更快
扩容 元素达到容量时需要扩容 不需要扩容,通过增加节点增加新元素
使用场景 频繁进行随机访问 频繁进行插入和删除

总结

  • Arrays 基本数据类型 数组大小不可变 提供方法有限
  • ArrayList 基于数组实现 增删慢 查询快 线程不安全
  • Vector 基于数组实现 增删慢 查询快 线程安全 频繁加锁 释放锁 读写效率低
  • LinkedList 基于双链表实现 增删快 查询慢 线程不安全
相关推荐
白緢几秒前
嵌入式 Linux + 内核开发高频问题及排查
java·linux·运维
juniperhan12 分钟前
Flink 系列第4篇:Flink 时间系统与 Timer 定时器实战精讲
java·大数据·数据仓库·flink
超级大只老咪14 分钟前
一维度前缀和解题通用模板(java)
java·开发语言·算法
历程里程碑21 分钟前
1 . Git本地操作:版本控制 跨平台协作 仓库核心
java·开发语言·数据结构·c++·git·gitee·github
hekung27 分钟前
maven的lifecycle与idea的run
java·maven
阿维的博客日记34 分钟前
为什么 ConcurrentHashMap 采用 synchronized 加锁而不采用ReentrantLock
java·juc
阿丰资源42 分钟前
java项目(附资料)-基于SpringBoot+MyBatisPlus+MySQL+Layui的药品管理系统
java·spring boot·mysql
云恒要逆袭43 分钟前
Java SE、EE、ME到底啥区别?我被这个问题困扰了一整年
java·java ee
鱼鳞_1 小时前
Java学习笔记_Day27(Stream流)
java·笔记·学习
身如柳絮随风扬1 小时前
Servlet:访问流程、核心接口与生命周期
java·servlet·web