java中List接口怎么实现类
发表于:2025-11-07 作者:千家信息网编辑
千家信息网最后更新 2025年11月07日,这篇文章主要讲解了"java中List接口怎么实现类",文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习"java中List接口怎么实现类"吧!List接口介
千家信息网最后更新 2025年11月07日java中List接口怎么实现类
这篇文章主要讲解了"java中List接口怎么实现类",文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习"java中List接口怎么实现类"吧!
List接口介绍-ArrayList
有序、可重复
线程不安全,因为没有synchronized修饰
ArrayList源码结论
ArrayList中维护了一个Object类型的数组elementData。
transient Object[] elementData; // transient 表示该属性不会被序列化
当创建ArrayList对象时,如果使用的是无参构造器,则初始elementData容量为0,第一次添加,则扩容elementData为10,如果需要再次扩容,则扩容elementData为1.5倍
如果使用的是指定大小的构造器,则初始elementData容量为指定大小,如果需要扩容,则直接扩容elementData为1.5倍。
ArrayList源码分析
List list = new ArrayList(); for(int i = 0; i < 10; i++) { list.add(1); }容器初始化为一个空数组
public ArrayList() { this.elementData = DEFAULTCAPACITY_EMPTY_ELEMENTDATA; } private static final Object[] DEFAULTCAPACITY_EMPTY_ELEMENTDATA = {};执行add方法
public boolean add(E e) { ensureCapacityInternal(size + 1); // Increments modCount!! elementData[size++] = e; return true; }先确定是否要扩容
再执行扩容操作
private void ensureCapacityInternal(int minCapacity) { if (elementData == DEFAULTCAPACITY_EMPTY_ELEMENTDATA) { minCapacity = Math.max(DEFAULT_CAPACITY, minCapacity); //(10,1) } ensureExplicitCapacity(minCapacity); }先确定elementData是否是空数组,如果是空数组就赋给minCapacity最小容量10(DEFAULT_CAPACITY为10)
private void ensureExplicitCapacity(int minCapacity) { modCount++; //记录当前集合被修改的次数 // overflow-conscious code if (minCapacity - elementData.length > 0) grow(minCapacity); }如果最小容量大于elementData实际大小的话,就执行扩容
private void grow(int minCapacity) { // overflow-conscious code int oldCapacity = elementData.length; int newCapacity = oldCapacity + (oldCapacity >> 1); //扩容为1.5倍 if (newCapacity - minCapacity < 0) //newCapacity=0 第一次的时候执行 newCapacity = minCapacity; if (newCapacity - MAX_ARRAY_SIZE > 0) newCapacity = hugeCapacity(minCapacity); // minCapacity is usually close to size, so this is a win: elementData = Arrays.copyOf(elementData, newCapacity); }感谢各位的阅读,以上就是"java中List接口怎么实现类"的内容了,经过本文的学习后,相信大家对java中List接口怎么实现类这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是,小编将为大家推送更多相关知识点的文章,欢迎关注!
接口
容量
数组
大小
学习
最小
内容
源码
构造器
有序
安全
再次
实际
容器
对象
就是
属性
序列
思路
情况
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
网络安全培训中心二期
台州营销网络技术包括什么
网站数据库怎么下
人工智能对网络安全的保护
数据库应用格式
中国提供东盟的网络安全产品
安装用友数据库闪一下
部队网络安全承诺保证书模板
美元对人民币数据库编程序
磁盘清理后出现音频服务器未开启
oracle数据库部署详细流程
网络安全股票市值
金仓数据库初始化失败
快速软件开发 微盘
网络安全审查认证中心王连印
数据库字段特定值唯一约束
access数据库好用吗
工行软件开发中心视频
固镇软件开发商
学院网络安全保障方案
什么是数据库污染
有效的企业内网网络安全
数据库datejsp输出
软件怎么修改数据库
红领巾广播站网络安全
集团公司网络安全工作目标
带网络安全模式没有输入法
天河网络安全服务哪个品牌好
计算机网络技术专业单招面试
杨浦区全过程网络技术创新服务