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

常州手机网站制作公众号seo排名优化

常州手机网站制作,公众号seo排名优化,安康做网站的公司,福州网站建设精英一、ArrayList 简介 ArrayList 是 Java 集合框架中基于数组实现的可变长度列表,其核心特性是: 支持随机访问(通过索引)支持动态扩容插入/删除效率较低(非尾部操作) 二、底层数据结构 // JDK 11 transien…

一、ArrayList 简介

ArrayList 是 Java 集合框架中基于数组实现的可变长度列表,其核心特性是:

  • 支持随机访问(通过索引)
  • 支持动态扩容
  • 插入/删除效率较低(非尾部操作)

二、底层数据结构

// JDK 11+
transient Object[] elementData; // 实际存储元素的数组

三、容量与初始状态

默认构造函数

public ArrayList() {this.elementData = DEFAULTCAPACITY_EMPTY_ELEMENTDATA;
}

默认初始值为一个空数组,不分配空间,首次添加元素时分配容量。


指定初始容量

public ArrayList(int initialCapacity) {if (initialCapacity > 0) {this.elementData = new Object[initialCapacity];}
}

开发中建议:尽量提前估算容量,减少扩容次数


四、扩容机制核心原理

触发条件:

当新增元素导致 size > elementData.length 时触发扩容。


扩容策略:

新容量 = 原容量 + (原容量 >> 1) = 原容量 * 1.5

例如:

  • 当前容量 10 → 扩容后为 15
  • 当前容量 15 → 扩容后为 22

五、源码详解(以 JDK 8 为例)

添加元素核心方法:

public boolean add(E e) {ensureCapacityInternal(size + 1); // 确保有容量elementData[size++] = e;return true;
}

ensureCapacityInternal(int minCapacity)

private void ensureCapacityInternal(int minCapacity) {if (elementData == DEFAULTCAPACITY_EMPTY_ELEMENTDATA) {minCapacity = Math.max(DEFAULT_CAPACITY, minCapacity);}ensureExplicitCapacity(minCapacity);
}

ensureExplicitCapacity(int minCapacity)

private void ensureExplicitCapacity(int minCapacity) {modCount++; // fail-fast 标识if (minCapacity - elementData.length > 0)grow(minCapacity); // 核心:扩容方法
}

grow(int minCapacity)

private void grow(int minCapacity) {int oldCapacity = elementData.length;int newCapacity = oldCapacity + (oldCapacity >> 1); // 扩容1.5倍if (newCapacity - minCapacity < 0)newCapacity = minCapacity; // 不够就按最小需求扩if (newCapacity - MAX_ARRAY_SIZE > 0)newCapacity = hugeCapacity(minCapacity);elementData = Arrays.copyOf(elementData, newCapacity); // 复制数组
}

六、最大容量限制

private static final int MAX_ARRAY_SIZE = Integer.MAX_VALUE - 8;

超过该限制会抛出 OutOfMemoryError


七、扩容操作的成本

  • 使用 Arrays.copyOf() 进行数组复制,时间复杂度为 O(n)
  • 多次扩容会引起频繁复制,影响性能

八、如何避免频繁扩容?

方式一:指定初始容量

List<String> list = new ArrayList<>(1000); // 预估大小

方式二:批量添加前调用 ensureCapacity

list.ensureCapacity(10000); // 批量操作前手动扩容

九、总结对比:不同初始化方式

构造方式初始容量首次添加触发扩容是否推荐
new ArrayList()0是(容量为10)⚠️ 慎用
new ArrayList(20)20✅ 推荐
new ArrayList(list)原容量✅ 推荐

十、扩容流程图

graph TD
A[add(e)] --> B[ensureCapacityInternal]
B --> C[ensureExplicitCapacity]
C --> D{容量够吗?}
D -- 是 --> E[添加成功]
D -- 否 --> F[grow 扩容]
F --> G[复制新数组]
G --> E

十一、常见面试题

Q1:ArrayList 每次扩容增长多少?

  • 默认是 1.5 倍(即 old + old/2

Q2:频繁 add 元素时怎么优化?

  • 预估大小,构造时指定初始容量
  • 或调用 ensureCapacity

Q3:ArrayList 最大能容纳多少元素?

  • Integer.MAX_VALUE - 8 ≈ 2^31 - 9

十二、总结

点位描述
数据结构动态数组 Object[]
扩容触发新增元素导致数组容量不够
扩容增长率1.5倍
拷贝机制Arrays.copyOf() 整体复制
最大容量Integer.MAX_VALUE - 8
性能建议尽量设定初始容量,避免频繁扩容
http://www.dtcms.com/wzjs/245346.html

相关文章:

  • 抖音制作图片的软件360优化大师旧版
  • wordpress 4.7.2seo实战教程
  • 网站做会员用什么源码建站cms
  • 网站免费观看seo薪资水平
  • opencart做的网站惠州seo关键词
  • 娱乐网站 建站软件防恶意点击软件
  • 余江区建设局网站百度移动应用
  • 网站推送怎么做经典seo伪原创
  • 深圳高端电商网站建设者一个新产品怎么推广
  • vi设计 站酷企业网络组建方案
  • 网站维护案例分析网络搭建是干什么的
  • 网站制作难点网络推广员是干什么的
  • 广州17做网站事件营销的概念
  • 鄂尔多斯市网站建设seo案例分析方案
  • 昆山网站建设推荐东莞百度seo在哪里
  • 网站 搭建 公司网课培训机构排名前十
  • 电视台网站建设网站怎么优化关键词快速提升排名
  • 成都网站设计公司 网络服务班级优化大师官方免费下载
  • 中国移动网站建设兰州网站开发公司
  • 高校门户网站的建设方案seo文章优化方法
  • 汉中做网站的电话优化的意思
  • 常州制作网站公司2345网址导航下载桌面
  • 长春求推荐好的网站优化推广男生技能培训班有哪些
  • 大连英文网站建设网站排名优化课程
  • 武汉 开发 公司 网站建设实时热点新闻
  • vi设计案例赏析网站优化培训学校
  • 做推广需要网站吗怎么开网站
  • 遨游建站ai智能营销系统
  • 免费成品网站模板下载网络营销案例成功案例
  • 网站被挂马原因网络营销是做什么的