ArrayList原码分析和效率分析(三)

##ArrayList原码分析和效率分析(三)

查操作

contains(Object o):如果包含元素o,则返回为true

get(int index):返回指定索引的元素
在这里插入图片描述

indexOf( Object o ):返回此列表中指定元素的第一次出现的索引,如果列表不包含此元素,返回-1
在这里插入图片描述

lastindexOf( Object o ):返回此列表中指定元素的最后一次出现的索引,如果列表不包含此元素,返回-1
在这里插入图片描述

isEmpty():如果列表为空,返回true.

在这里插入图片描述

特征分析
增删慢:
增加慢:
	1, 有可能触发扩容操作。在扩容方法操作中,从原数组拷贝数据到新数组浪费时间,同时在扩容操作会出现无效内
	存销毁问题,同样浪费时间。
	2. 插入数据到指定下标位置,从插入位置开始,数组中的其他数据会整体向后移动。移动操作浪费时间。
删除慢:
	1. 删除指定下标元素,数组中的元素整体向前移动。
	2. 删除元素较多情况下,会导致空间冗余。空间效率较低
查询快:
【寻址操作】
ArrayList底层数据操作方式为数组方式,数组+下标获取对应元素的操作效率是非常高!!!是CPU根据对应【地址】直接访问操作。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值