ArrayList和hashMap代码解析

warning: 这篇文章距离上次修改已过1453天,其中的内容可能已经有所变动。

**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

版权声明 ▶ 本网站名称:我的学习笔记
▶ 本文链接:https://ooolo.net/article/73.html
▶ 本网站的文章部分内容可能来源于网络,仅供大家学习与参考,如有侵权,请联系站长进行核实删除。
▶ 转载本站文章需要遵守:商业转载请联系站长,非商业转载请注明出处!!!

最后修改于:2020年04月24日 17:09

添加新评论

icon_mrgreen.pngicon_neutral.pngicon_twisted.pngicon_arrow.pngicon_eek.pngicon_smile.pngicon_confused.pngicon_cool.pngicon_evil.pngicon_biggrin.pngicon_idea.pngicon_redface.pngicon_razz.pngicon_rolleyes.pngicon_wink.pngicon_cry.pngicon_surprised.pngicon_lol.pngicon_mad.pngicon_sad.pngicon_exclaim.pngicon_question.png