1,ArrayList面试必问
-
说说ArrayList和LinkedList的区别?
ArrayList基于数组实现,LinkedList基于链表实现,不同的数据结构决定了ArrayList查询效率比较高,而LinkedList插入删除效率比较高,反过来就比较慢了。
-
ArrayList默认初始容量为多少?按照几倍来扩容?
10,1.5倍。
-
说说数组扩容的原理?
ArrayList扩容调用的是Array.copyof函数,把老数组遍历赋值给新数组返回。
-
说说ArrayList常见方法的时间复杂度?
- get方法通过下标获取元素,时间复杂度为O(1)
- add方法直接添加会添加到集合的尾部,时间复杂度为O(1)
- add方法通过下标添加到非尾部会引起数组的批量移动,时间复杂度为O(n),否则为O(1)
- remove方法通过下标删除非尾部元素引起数组批量移动,时间复杂度为O(n),反之则为O(1)
- remove方法根据对象删除需要遍历集合,时间复杂度为O(n),如果删除的为非尾部元素,会使数组批量移动,时间复杂度为O(n^2)
总之,通过下标操作的时间复杂度为O(1),如果触发了数组的批量移动,时间复杂度为O(n),如果通过对象操作需要遍历集合,时间复杂度已经为O(n),若同时触发了数组的移动,时间复杂度为O(n^2).
-
ArrayList和vector的区别
- 最大的区别在于线程是否安全
- 其次Vector是两倍扩容
- 最后就是在不指定大小的情况下,ArrayList容量初始化是在添加元素的时候,而Vector有一个无参构造器直接初始化为10
2,Debug ArrayList源码
由于1.7和1.8几乎没什么变化,本文以jdk1.8为例。
2.1 用Debug分析一个元素是如何add进ArrayList
编写测试用例,打上断点:
先分析构造函数如何初始化,关键步骤如下:
element