ArrayList和hashMap代码解析

2023-07-17 18:46:23 浏览数 (4)

**1、ArrayList:** Arraylist 默认大小是10 ArrayLIst扩容过程:在add的时候会先做判断:如果先加 1的容量大于默认存储大小则要调用grow()方法,grow()方法会扩容到原来大小的1.5倍,然后调用Arrays.copyof()传入旧数据和新容量,该方法的内部调用的是System.arrayCopy()方法创建新数组并且返回。

**2、 hashMap** 默认大小16 当发现容量到达12是会调用resize()方法 首先通过oldtable.length 获取原oldCap 然后计算新的容量 旧容量的两倍 然后new一个容量为新容量的新newTab 然后就是遍历oldtab数据hash到新newTab上 然后返回newTab

0 人点赞