首先本质区别
array : 数组,他是本地的数据结构
arrayList: 他是java中的一个集合类,既然是类,那么就可以去创建他的对象,然后去使用他的方法
容量方面区别:
array: 数组他是有一个固定的容量的,我们已知,通过length来过去他的长度
arrayList: 他是集合,内部可以自动的进行扩容,所以说他比array更加的灵活,通过size()来判断集合元素的,一般size和length是相等的。
存储方面:
array: 他可以存出基本类型和对象
arrayList: 他只能存储对象,如果是基本类型,就需要去存储他的包装类,所以他的内存开销能大一点int4位,Integer位32位
查找一个数据:
array: array在查找固定的数据的时候的时间复杂度为O(1),查找某个元素的时候是O(logn)
arrayList: arayList在查找固定的数据的时候的时间复杂度也为O(1)。
插入一个数据:
插入一个数据的时候array的时间复杂度是O(1),对于arrayList来说的话,如果不触发resize和array插入一样的,如果触发了resize(),那么时间复杂度就变成了O(logn);
类型安全:
array : 不支持泛型,程序运行时抛出ArrayStoreExeption来告知类型异常
arrayList: 支持泛型,允许程序在编译时检查集合中对象类型的正确性
维度:
array: 我们可以自定义维度,如int[][] int [][][[]
arrayList: 不允许自定义维度;