博客
关于我
收藏:Java集合ArrayList源码解读
阅读量:163 次
发布时间:2019-02-26

本文共 723 字,大约阅读时间需要 2 分钟。

ArrayList的内部原理与实现

1. 基本结构与字段

ArrayList基于动态数组实现,主要字段包括:

  • elementData:一个私有的Object数组,用于存储对象的引用。
  • size:表示ArrayList的长度。
  • modCount:用于检测结构修改次数,防止并发修改。

2. 构造函数

  • 空ArrayList的优化:使用静态空数组EMPTY_ELEMENTDATA,节省内存。
  • 指定容量:直接初始化大小为指定值的数组。
  • 从集合转换:将集合转换为数组,提高效率。

3. 容量增长策略

  • 动态扩展:通过grow方法,容量按1.5倍增长或达到需求。
  • 最大容量限制:不得超过MAX_ARRAY_SIZE(Integer.MAX_VALUE - 8)。
  • 高效操作:使用System.arraycopy进行元素移动和复制。

4. 插入与删除操作

  • 插入:使用System.arraycopy移动元素,腾出空间插入新元素。
  • 按索引删除:拷贝元素到前一个位置,调整索引并置null。
  • 按对象删除:通过遍历查找并删除指定对象。

5. 查找与清除

  • 查找:通过遍历调用equals判断元素存在。
  • 清除:将所有元素引用置null,等待垃圾回收。

6. 高效操作与转换

  • 高效拷贝:使用System.arraycopyArrays.copyOf进行快速操作。
  • 数组转换:谨慎使用泛型方法,避免类型转换异常。

7. 迭代器机制

  • modCount检测:防止结构修改导致的并发异常。
  • 高效遍历:通过优化方法确保高效和安全。

8. 总结

ArrayList通过动态数组和高效操作实现,提供灵活的数据结构。其智能容量增长、快速元素操作和结构检测机制,使其在Java中广泛应用。

转载地址:http://oypf.baihongyu.com/

你可能感兴趣的文章
svn访问报错500
查看>>
sum(a.YYSR) over (partition by a.hy_dm) 不需要像group by那样需要分组函数。方便。
查看>>
ORCHARD 是什么?
查看>>
Struts2中使用Session的两种方法
查看>>
Stream API:filter、map和flatMap 的用法
查看>>
STM32工作笔记0032---编写跑马灯实验---寄存器版本
查看>>
Static--用法介绍
查看>>
ssm旅游信息管理系统的设计与实现bus56(程序+开题)
查看>>
order by rand()
查看>>
SSM(Spring+SpringMvc+Mybatis)整合开发笔记
查看>>
ViewHolder的改进写法
查看>>
Orderer节点启动报错解决方案:Not bootstrapping because of 3 existing channels
查看>>
org.apache.axis2.AxisFault: org.apache.axis2.databinding.ADBException: Unexpected subelement profile
查看>>
sql查询中 查询字段数据类型 int 与 String 出现问题
查看>>
org.apache.commons.beanutils.BasicDynaBean cannot be cast to ...
查看>>
org.apache.dubbo.common.serialize.SerializationException: com.alibaba.fastjson2.JSONException: not s
查看>>
sqlserver学习笔记(三)—— 为数据库添加新的用户
查看>>
org.apache.http.conn.HttpHostConnectException: Connection to refused
查看>>
org.apache.ibatis.binding.BindingException: Invalid bound statement错误一例
查看>>
org.apache.ibatis.exceptions.PersistenceException:
查看>>