当前位置: 首页 > news >正文

凡科建设网站入门版好不360推广开户

凡科建设网站入门版好不,360推广开户,企业网站 需求,网站制作公司网站设计公司Java源码系列:下方连接 http://t.csdn.cn/Nwzed 文章目录前言一、**ArrayList底层结构和源码分析**无参构造调用创建ArrayList集合无参构造总结:发文3个工作日后 up 会把总结放入前言部分,但也诚邀读者总结,可放入评论区有参构造…

Java源码系列:下方连接
http://t.csdn.cn/Nwzed


文章目录

  • 前言
  • 一、**ArrayList底层结构和源码分析**
    • 无参构造调用创建ArrayList集合
    • 无参构造总结:发文3个工作日后 up 会把总结放入前言部分,但也诚邀读者总结,可放入评论区
    • 有参构造器调用创建ArrayList集合


前言

ArrayList集合总结:发文3个工作日后 up 会把总结放入前言部分,可谓“温故而知新”。


提示:以下是本篇文章正文内容,下面案例可供参考

一、ArrayList底层结构和源码分析

![在这里插入图片描述](https://img-blog.csdnimg.cn/a231807b371b4e30a4f19426ecf45da6.png

无参构造调用创建ArrayList集合

在这里插入图片描述

创建ArrayList时没有传参数调用的无参构造,无参构造把默认的常量 DEFAULTCAPACITY_EMPTY_ELEMENTDATA
赋值给了成员变量 elementData,所以elementData初始化的时候就是一个空数组。
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述
从自动装箱出来,再次点进add方法会来到下面代码

在这里插入图片描述
进来 add 方法不是一上来就把 e 存入 elementData默认数组,而是先确保数组的容量够不够,因为默认的数组容量是空的没有指定数据的容量,而现在我们又在底层源码,没办法一上来就往一个空数组里面放数据,所有会先调用 ensureCapacityInternal(size + 1) 这时数组的size肯定是 0 , 0+1肯定大于1,拿到这个 1 后我们接着步入 ensureCapacityInternal方法。

在这里插入图片描述
步入到 ensureCapacityInternal 确保内部容量 方法就会把刚才的 1 传过来。接着调用 calculateCapacity计算容量 方法来确定数组的容量。

在这里插入图片描述

步入到 calculateCapacity 方法,先判断传入的 elementData和默认的DEFAULTCAPACITY_EMPTY_ELEMENTDATA空数组是否相等,相等会在这里拿到默认初始容量 DEFAULT_CAPACITY (10)和 add 方法传过来的 1 ,调用 Math.max()进行比较。

在这里插入图片描述
在这里插入图片描述

继续步入 Math.max()方法,里面第一个参数是 默认初始容量 DEFAULT_CAPACITY (10),第二个是 1,接下来进行判断 a>=b? 也就是 10>=1?,为true返回 a(DEFAULT_CAPACITY )。

在这里插入图片描述
得到结果 后一路返回到 ensureCapacityInternal 方法,因为上一次调用 ensureCapacityInternal 执行的是ensureExplicitCapacity里面的calculateCapacity计算容量方法进行容量的确定,一路返回过来就该执行ensureExplicitCapacity 确保显式容量方法了。
在这里插入图片描述
继续步入到确保显示容量,一进来就会让 modCount++ 这是为了确保多线程进来随意篡改集合内容做的计数器。

在这里插入图片描述
在这里插入图片描述
继续步入 grow 方法,这时才真正进行扩容,

在这里插入图片描述
将 minCapactiy的值赋值给newCapactiy后再进行判断是否大于最大值,其实这个判断不是给我们通过无参构造使用的,因为无参构造的初始容量就是10,不可能比最大的值大,到最后调用 Arrays.copyOf( )方法进行数组的拷贝,然后赋值给 elementData 覆盖一开始的空数组,这样就完成了ArrayList的初始化。
Arrays.copyOf( )方法在进行数组的拷贝时会保留原来数组的内容到新的数组。
第一次初始化扩容数组的长度是 10 ,之后的扩容就是 1.5 倍。
在这里插入图片描述

在这里插入图片描述

等copyOf执行完后会一路返回到刚开始调用到 add 的地方,把 e 的值赋值给 elementData[ size (0)]数组下标为 0 的地方,赋值之后再让 size++,以便下一个数据存入下标为 1 的位置。

在这里插入图片描述
在这里插入图片描述
由于我们最外层写的是一个for循环添加ArrayList数据,所以以上步骤会重复执行。但要注意的是,只有在存入数据时数组满了,才会去扩容。数组的扩容我们并不需要去担心,因为在调用 add 方法添加数据时,会先调用 ensureCapacityInternal(size + 1); 方法进行确保内部容量计算,如果当前数组的长度加1减去elementData.length 大于 0 就进行扩容。
if (minCapacity - elementData.length > 0) grow(minCapacity);

无参构造总结:发文3个工作日后 up 会把总结放入前言部分,但也诚邀读者总结,可放入评论区

有参构造器调用创建ArrayList集合

在这里插入图片描述
点进有参构造器,就会拿到传入的int数据去构建一个 new Object[ ] 的数组,赋值给 elementData,如果传过来的是一个0就和无参构造的一样,如果传入的是负数就抛异常。
在这里插入图片描述
除了初始化时不一样,其他地方都是差不多的,比如自动装箱,然后调用 add 方法,然后去调用ensureCapacityInternal方法
在这里插入图片描述
在这里插入图片描述
调用ensureCapacityInternal方法时,elementData数组的长度不再是 0 ,而是我们自定义的长度。
在这里插入图片描述
在往ArrayList添加数据时,如果没有超出自定义的数组边界是不会去调用 grow 方法进行数组扩容的。
在这里插入图片描述
然后一路返回到 add 方法进行元素的添加,直到添加元素时ensureCapacityInternal方法计算出 if(minCapacity - elementData.length > 0) grow(minCapacity); 时才会去做1.5倍扩容。
在这里插入图片描述

http://www.15wanjia.com/news/34547.html

相关文章:

  • 网站建设与管理实训课程站长工具seo排名
  • 网络游戏服务网天津seo排名效果好
  • 帝国cms做投资网站源码企业网络营销策划书
  • 旅游网站设计策划书低价刷粉网站推广
  • flash网站优化中山疫情最新消息
  • 搜索引擎优化排名seoseo软件简单易排名稳定
  • php 优化网站建设域名解析查询工具
  • 用源码做网站外包网络推广公司推广网站
  • 东莞网站快速优化排名59软文网
  • asp.net做织梦网站制作网页一般多少钱
  • 南京移动网站建设百度推广官网首页
  • 新浪云sae免费wordpress网站推广网站源码
  • 如何设置网站icon磁力搜索引擎torrentkitty
  • 17网站一起做网店池尾商圈站长工具中文
  • 网站建设 环保 图片友情链接检查
  • 企业服务类型有哪些重庆快速排名优化
  • 做时时彩网站合法的吗购物网站哪个最好
  • php成品网站游戏推广一个月能拿多少钱
  • 哪个免费建站好百度快照入口
  • 做网站推广邢台营销推广技巧
  • 石家庄做外贸的网站建设厦门seo管理
  • thinkphp企业网站模板下载网站建设黄页免费观看
  • godday网站建设抖音推广引流平台
  • 个人可以做行业网站吗东莞优化排名公司
  • 中山哪里有做微网站的网络推广工作内容
  • 蚌埠网站排名关键词搜索引擎工具爱站
  • 厦门的服装商城网站建设嵌入式培训班一般多少钱
  • 网站建设作为seo自动点击排名
  • wordpress多站点是什么意思真正免费建站网站
  • 网站建设公司发展网络营销策划包括哪些内容