数组是最基本的数据结构之一,当然我们每天也都在使用数组,那么你知道数组的CURD的操作的背后是什么吗?我来说一下,也可能有错误的地方,欢迎大佬指出!
在面试时候,进常会被问这么一个问题,数组和链表的区别是什么?
数组优点:
- 支持随机访问
- 查找速度快
数组缺点:
- 插入和删除效率低,可能会造成浪费内存的问题
- 大小固定,不支持动态扩展
- 要求内存空间必须连续
链表优点:
- 插入删除速度快
- 不需要固定大小
链表缺点:
- 不能随机查找,必须从第一个开始遍历,查找效率低
复杂度比较:
- 数组根据下标进行访问时,时间复杂度为O(1),进行插入和删除操作时,时间复杂度为O(n)
- 链表进行访问时,时间复杂度为O(n),进行插入和删除时,时间复杂度为O(1)
不知道你们有没有想过数组的插入和删除为什么效率不高?
这里明确一下数组的官方定义,后面我们会用到,数组(Array):是用一组连续的内存空间,来存储一组相同类型的数据结构,是一种 线性表
那么到这里你可能就会有点懂了,没错,数组是一种线性表结构,当你要插入或者删除某个数据的时候,剩下的数据或者部分的数据都需要向前、或许向后移动一次或者几次这样才能实现插入或者删除,这也就是说为什么数组不适合插入和删除操作的根本原因
和数组类似的还有我们每天都在使用的像ArrayList之类的,这种我们叫做容器类(就是封装了某一种基本数据类型的类)
那么就会有这么两个问题
- 1.ArrayList和Array的的区别是什么?
它和数组区别一个是封装了基本的操作,我们只需要调用API,而不需要去实现一个个操作(就是省事了)
还有一个最大的区别就是ArrayList支持动态扩容,不需要事先指定大小,当内存不够时自动扩容为1.5倍
- 2.什么时候使用ArrayList,什么时候使用Array?
1.ArrayList不能存储基本的护具类型,比如int,需要封装成integer,封装时有一定的消耗,如果你存储基本数据类型,请选用数组
2.如果大小事先已知,且操作简单,可以使用ArrayList
3.总结一下,基本的开始使用ArrayList就好,省时,省力,如果是非常底层的开发,对性能要求非常严格,数组就是首选