【Java集合类面试二十六】、介绍一下ArrayList的数据结构?

文章底部有个人公众号:热爱技术的小郑。主要分享开发知识、学习资料、毕业设计指导等。有兴趣的可以关注一下。为何分享? 踩过的坑没必要让别人在再踩,自己复盘也能加深记忆。利己利人、所谓双赢。

面试官:介绍一下ArrayList的数据结构?

参考答案:

ArrayList的底层是用数组来实现的,默认第一次插入元素时创建大小为10的数组,超出限制时会增加50%的容量,并且数据以 System.arraycopy() 复制到新的数组,因此最好能给出数组大小的预估值。

按数组下标访问元素的性能很高,这是数组的基本优势。直接在数组末尾加入元素的性能也高,但如果按下标插入、删除元素,则要用 System.arraycopy() 来移动部分受影响的元素,性能就变差了,这是基本劣势。

相关推荐
凤凰战士芭比Q11 分钟前
Nexus仓库(maven仓库、Yum仓库、APT仓库)
java·maven
864记忆25 分钟前
Linux操作系统自带的测试内存泄漏的命令
java·linux·运维
Jul1en_38 分钟前
【算法】分治-归并类题目
java·算法·leetcode·排序算法
tryxr40 分钟前
volatile 的作用
java·jvm·volatile·指令重排序
独自归家的兔1 小时前
Java Robot 详解:系统级鼠标 / 键盘模拟的核心原理与实战
java·开发语言
岳轩子1 小时前
DDD领域驱动设计:核心概念、实践结构与框架对比
java·spring
ArabySide1 小时前
【Java】重构之善用多态解耦,记录一次模板方法实践
java·重构·模板方法模式
wanghowie1 小时前
01.03 Java基础篇|面向对象核心与设计实践
java·开发语言
vortex51 小时前
ORM是什么?如何理解ORM?ORM的优缺点?
java·数据库·sql·mysql·oracle·orm
Algebraaaaa1 小时前
为什么线程阻塞要用.join而不是.wait
java·c++·python