ArrayList扩容机制:流程图+源码解析给你整得明明白白

本文涉及的产品
云解析 DNS,旗舰版 1个月
全局流量管理 GTM,标准版 1个月
公共DNS(含HTTPDNS解析),每月1000万次HTTP解析
简介: ArrayList的扩容机制是java基础面试题,是每个java程序员学习路上都会遇到的一个问题,也是大多数人第一次看的java源码,今天布狼牙就带大家来看一下源码.

流程图:

图片.png

add方法:

/**ArrayList的add方法有几个重载,最后会来到这个方法*/privatevoidadd(Ee, Object[] elementData, ints) {
if (s==elementData.length)  //判断是否需要扩容elementData=grow();  //如果需要扩容调用扩容方法elementData[s] =e;  //将数据插入到数组尾size=s+1;  //数组长度更新}

grow方法:

//add方法里调用的grow方法privateObject[] grow() {
returngrow(size+1);
    }    
//实际调用的重载方法privateObject[] grow(intminCapacity) {
//newCapacity就是获得新的容量//Arrays.copyOf是把之前的数组复制到新的数组里returnelementData=Arrays.copyOf(elementData,newCapacity(minCapacity));
    }

newCapacity方法:

//获得扩容后容量privateintnewCapacity(intminCapacity) {
intoldCapacity=elementData.length;
//这句比较关键,新的容量=旧容量+旧容量右移1位(相当于除2)intnewCapacity=oldCapacity+ (oldCapacity>>1);
//判断溢出的,不用管if (newCapacity-minCapacity<=0) {
if (elementData==DEFAULTCAPACITY_EMPTY_ELEMENTDATA)
returnMath.max(DEFAULT_CAPACITY, minCapacity);
if (minCapacity<0) // overflowthrownewOutOfMemoryError();
returnminCapacity;
        }
//如果不溢出就返回新容量,否则返回int类型上限2147483647-8return (newCapacity-MAX_ARRAY_SIZE<=0)
?newCapacity            : hugeCapacity(minCapacity);
    }
相关文章
|
15天前
|
存储 NoSQL Redis
redis 6源码解析之 object
redis 6源码解析之 object
43 6
|
8天前
|
开发者 Python
深入解析Python `httpx`源码,探索现代HTTP客户端的秘密!
深入解析Python `httpx`源码,探索现代HTTP客户端的秘密!
31 1
|
8天前
|
开发者 Python
深入解析Python `requests`库源码,揭开HTTP请求的神秘面纱!
深入解析Python `requests`库源码,揭开HTTP请求的神秘面纱!
21 1
|
22天前
|
负载均衡 Java Spring
@EnableFeignClients注解源码解析
@EnableFeignClients注解源码解析
47 14
|
15天前
|
NoSQL Redis
redis 6源码解析之 ziplist
redis 6源码解析之 ziplist
16 5
|
22天前
|
负载均衡 Java API
Feign 进行rpc 调用时使用ribbon负载均衡源码解析
Feign 进行rpc 调用时使用ribbon负载均衡源码解析
38 11
|
3天前
|
算法 安全 Java
深入解析Java多线程:源码级别的分析与实践
深入解析Java多线程:源码级别的分析与实践
|
2月前
|
XML Java 数据格式
深度解析 Spring 源码:从 BeanDefinition 源码探索 Bean 的本质
深度解析 Spring 源码:从 BeanDefinition 源码探索 Bean 的本质
67 3
|
22天前
|
Java Spring 容器
Spring Boot 启动源码解析结合Spring Bean生命周期分析
Spring Boot 启动源码解析结合Spring Bean生命周期分析
60 11
|
22天前
|
Java 容器 Spring
@Import 源码解析
@Import 源码解析
36 10

热门文章

最新文章

推荐镜像

更多