黑马程序员技术交流社区

标题: 通过视频和看源码的堆arraylist的理解 [打印本页]

作者: 苗润    时间: 2014-5-14 00:38
标题: 通过视频和看源码的堆arraylist的理解
在jdk1.7版本中 当你创建一个arraylist时  如果参数为空 则默认分配10快空间,当你存入的数据大于10是 将会自动扩容,扩容的机制是:在7.0之前,是按照原有大小*3/2+1   例如 现在为10 当存入第11个是 则容量扩充为10*3 /2 +1  = 16  在7.0和8.0中  扩容机制变成了 old + (old>>1) 变为原来的1.5倍  例如现在为10 则添加第11个元素是  变为 10 + 10/2  (右移一位相当于除以2 )
如果你已经确定ArrayList最终要存放多少个元素 那么最好在构造的时候直接在构造方法传入参数 要不如果你定义的过小 存入数据又过大时  会不停地触发扩容操作 这将浪费资源和时间  如果刚开始没法确定大小  但是后面的时候可以  就可以调用ensureCapacity(size)方法确定要扩容为多大


作者: jsjchenlong    时间: 2014-5-14 00:41
谢谢分享,学习一下
作者: 李小新H    时间: 2014-5-14 07:33
顶一个!!!




欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/) 黑马程序员IT技术论坛 X3.2