java中List接口怎么实现类
发表于:2025-02-01 作者:千家信息网编辑
千家信息网最后更新 2025年02月01日,这篇文章主要讲解了"java中List接口怎么实现类",文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习"java中List接口怎么实现类"吧!List接口介
千家信息网最后更新 2025年02月01日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安全错误
数据库的锁怎样保障安全
导出数据库多个用户的数据
ps网络安全手册答辩
网络安全法合规案例
浙江拓讯网络技术有限公司被告
华岩共享数据库
网络技术三级有用
游戏数据库怎么破解
服务器托管的安全维护
缓存一般放什么数据库
asp条件查询数据库
pks网络安全
网络安全宣传小报图片
以太网网络服务器安装
绝地求生最菜的服务器
tomcat 日志服务器
香港服务器无需实名
达梦数据库用户登录失败
山西大学的服务器云主机
128服务器安全吗
与网络安全相关的学习
iis 网站服务器安全隐患
山东浪潮服务器续保费用
软件开发选择什么样的公司
河南创航网络技术有限公司
周村采购管理软件开发公司
无锡网络安全审计系统咨询
用户操作权限数据库怎么实现
农业银行软件开发中心工资
成都博软软件开发公司是一家
3d可视化系统软件开发工具