要点
- 线性表结构
- 连续的内存空间和相同的数据类型
低效的插入删除
- 如果要保持连续的分布,会涉及数据移位,最坏情况为O(n)
- 删除可以优化为标记删除
扩展
- 有了容器如ArrayList,数组是否没了用武之地?
(1) 如果指定了大小,又没有复杂操作,可直接用数组
(2) 容器不支持原始数据类型,比如int, long,用包装类又低效
注意
- 查找时间复杂度不一定为O(1), 根据下标访问才是O(1)
- Java的多维数组寻址不一定满足连续性,比如 int arr[][] = new int[3][],每一行数组的长度不一定相等,比如 arr[0] = {1}, arr[1]={1,2}
- Java原始类型的arr 分配在栈上,而new的内容{0,1,2}在椎上
- Java对象类型的arr 分配在栈上,堆上分为两部分,一部分是数组元素是存储对象的地址,是在连续的空间上,而具体对象是存储并不一定是连续的空间