ArrayList扩容原理

这篇博客深入探讨了ArrayList的扩容原理。当ArrayList达到容量上限时,它会进行扩容操作,将原有数组的数据复制到新的、更大的数组中。源码分析显示,扩容时新容量计算为原容量的1.5倍,但会受到MAX_ARRAY_SIZE的限制,以适应不同JVM的最大字节数组大小。若扩容导致新容量超过MAX_ARRAY_SIZE,则会根据实际需求调整新容量,确保在所有JVM上的兼容性。
摘要由CSDN通过智能技术生成

一、ArrayList扩容

ArrayList底层使用数组实现,当达到容量上限时,数组会扩容,然后将原数组数据拷贝到扩容后的数组。
ArrayList扩容测试:

 @org.junit.Test
    public void arrayListCapacityTest(){
   
        ArrayList<String> objects = new ArrayList<>();
        System.out.println(getCapacity(objects));
        int currentSize = 0;
        for(int i = 0; i< 100; i++){
   
            objects.add("add");
            if(getCapacity(objects) != currentSize){
   
                currentSize = getCapacity(objects);
                System.out.println
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值