C# 数组之ArrayList

Stella981
• 阅读 891

一、引言

ArrayList类相当于一种高级的动态数组,是Array类的升级版本。

一般的Array,底层是数组实现的,对于数据的查找和修改十分高效。但是有2个大的缺点,其一为增删低效,其二为数组长度时固定的,无法动态增加长度。

与一般的Array相比,ArrayList主要可以动态增加数组的长度。尽管实现了数据增删,但是由于底层还是数组,增删效率还是不高。


二、函数

声明之前需要引用命名空间:using System.Collections

创建:

声明时可指定长度,也可不指定:

ArrayList myList = new ArrayList();

ArrayList myList = new ArrayList(100);

属性:

名称

说明

Capacity

获取或设置 ArrayList 可包含的元素数。

Count

获取 ArrayList 中实际包含的元素数。

IsReadOnly

获取一个值,该值指示 ArrayList 是否为只读。

方法:

名称

描述

Add(Object)

增加(末尾)

将对象添加到 ArrayList 的结尾处。

Insert(index, Object)

插入(任意位置)

将元素插入 ArrayList 的指定索引处。

Clear()

全部删除

从 ArrayList 中移除所有元素。

Remove(Object)

移除(某对象)

从 ArrayList 中移除特定对象的第一个匹配项。

RemoveAt(index)

移除(某下标)

移除 ArrayList 的指定索引处的元素。

RemoveRange(index,count)

移除(一段)

移除ArrayList中,index开始,长度为count的数据

Clone()

克隆

创建 ArrayList 的浅表副本。

CopyTo(Array)

复制

从目标数组的开头开始,将整个 ArrayList 复制到兼容的一维 Array

SetRange(Int32, ICollection)

复制一段

复制 ArrayList 中一个子集合的元素。

Int IndexOf(Object)

查找

搜索指定 Object 并返回整个内的第一个匹配项的从零开始索引 ArrayList。

Bool Contains(Object)

包含

确定某元素是否在 ArrayList 中。

Reverse()

逆序

将整个 ArrayList 中元素的顺序反转。

Sort()

排序

对整个 ArrayList 中的元素进行排序。

访问:

ArrayList是数组,因此支持下标直接访问

ArrayList[index] = value;

遍历:

因为ArrayList可以存放任意类型的数据,因此遍历的时候,无法指定一种数据类型,因此:

foreach(Object obj in myList)

{

Console.WritLine(obj);

}

与数组转换:

  • 如果ArrayList里面,全是同一种类型,比如int,可以如下转换:

int[] A = ( int[] )Arrlist.ToArray( typeof(int) );

或者

**int[] A= new int[**Arrlist.Count];

Arrlist.CopyTo(A);

  • 如果ArrayList里面,不一定是同一种类型,可以如下转换:

object[] A = Arrlist.ToArray();


三、总结

关于数组扩容:

这是对ArrayList效率影响比较大的一个因素。
每当执行Add、AddRange、Insert、InsertRange等添加元素的方法,都会检查内部数组的容量是否不够了,如果是,它就会以当前容量的两倍来重新构建一个数组,将旧元素Copy到新数组中,然后丢弃旧数组,在这个临界点的扩容操作,应该来说是比较影响效率的。

比如,一个可能有200个元素的数据动态添加到一个以默认16个元素大小创建的ArrayList中,将会经过:

16*2*2*2*2 = 256

四次的扩容才会满足最终的要求,那么如果一开始就以:

ArrayList List = new ArrayList( 210 );

的方式创建ArrayList,不仅会减少4次数组创建和Copy的操作,还会减少内存使用。

所以说,正确的预估可能的元素,并且在适当的时候调用TrimSize方法是提高ArrayList使用效率的重要途径。

(1)数组的容量是固定的,而ArrayList的容量可以根据需要自动扩充

(2)ArrayList可以插入任意类型的数据,而数组必须是同一种类型

(3)ArrayList提供将只读和固定大小包装返回到集合的方法,而数组不提供

(4)ArrayList只是一维形式,而数组可以是多维的

(5)因为ArrayList主打动态数组,但是频繁的扩容会影响效率。因此在初始化的时候,就考虑好大概需要N个数据,初始大小比N稍大就好。

(6)不用频繁的使用indexOf、contains等,数组的查找也是遍历,并没有key、value等映射,效率不高。

写在最后的话:

对于一般的引用类型来说,这部分的影响不是很大,但是对于值类型来说,往ArrayList里面添加和修改元素,都会引起装箱和拆箱的操作,频繁的操作可能会影响一部分效率。但是恰恰对于大多数人,多数的应用都是使用值类型的数组。消除这个影响是没有办法的,除非你不用它,否则就要承担一部分的效率损失,不过这部分的损失不会很大。

点赞
收藏
评论区
推荐文章
blmius blmius
3年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
Wesley13 Wesley13
3年前
java将前端的json数组字符串转换为列表
记录下在前端通过ajax提交了一个json数组的字符串,在后端如何转换为列表。前端数据转化与请求varcontracts{id:'1',name:'yanggb合同1'},{id:'2',name:'yanggb合同2'},{id:'3',name:'yang
皕杰报表之UUID
​在我们用皕杰报表工具设计填报报表时,如何在新增行里自动增加id呢?能新增整数排序id吗?目前可以在新增行里自动增加id,但只能用uuid函数增加UUID编码,不能新增整数排序id。uuid函数说明:获取一个UUID,可以在填报表中用来创建数据ID语法:uuid()或uuid(sep)参数说明:sep布尔值,生成的uuid中是否包含分隔符'',缺省为
待兔 待兔
6个月前
手写Java HashMap源码
HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程22
Chase620 Chase620
3年前
ArrayList底层
一、ArrayList集合底层数据结构1.ArrayList集合介绍List集合的可调整大小数组实现。2.数组结构介绍增删快:每次增加删除元素,都需要更改数组长度、拷贝以及移除元素位置。查询快:由于数组在内存中是一块连续空间,因此可以根据地址索引的方式快速获
说说ArrayList的扩容机制
ArrayList是List接口的实现类,它是支持根据需要而动态增长的数组。java中标准数组是定长的,在数组被创建之后,它们不能被加长或缩短。这就意味着在创建数组时需要知道数组的所需长度,但有时我们需要动态程序中获取数组长度。ArrayList就是为此而生的,但是它不是线程安全的,外ArrayList按照插入的顺序来存放数据①ArrayList扩容发生
Wesley13 Wesley13
3年前
Java集合ArrayList源代码详细解析
一、ArrayList简介  ArrayList是可以动态增长和缩减的索引序列,它是基于数组实现的List类。  该类封装了一个动态再分配的Object\\数组,每一个类对象都有一个capacity属性,表示它们所封装的Object\\数组的长度,当向ArrayList中添加元素时,该属性值会自动增加。如果想ArrayList中添加大
Wesley13 Wesley13
3年前
PHP创建多级树型结构
<!lang:php<?php$areaarray(array('id'1,'pid'0,'name''中国'),array('id'5,'pid'0,'name''美国'),array('id'2,'pid'1,'name''吉林'),array('id'4,'pid'2,'n
Stella981 Stella981
3年前
ArrayList源码分析(JDK1.8)
概述ArrayList底层是基于 数组实现的,并且支持 动态扩容 的动态数组(变长的集合类)。ArrayList允许空值和重复的元素,当向ArrayList中添加元素数量大于其底层数组容量时,会通过 扩容机制 重新生成一个容量更大的数组。另外,由于ArrayList底层数据结构是数组,所以保证了在O(1)复杂度下完成随机查
Stella981 Stella981
3年前
LeetCode 5561. 获取生成数组中的最大值
文章目录1\.题目2\.解题1\.题目给你一个整数n。按下述规则生成一个长度为n1的数组nums:nums00nums11当2<2i<n时,nums2inumsi