Array与ArrayList对比

1.精辟阐述
可以将ArrayList想象成一种“会自动扩增容量的Array”。

2.简介
Array([]):最高效,但其容量固定且无法动态改变;
ArrayList:容量可动态增长,但牺牲效率。

3.建议
基于效率和类型检验,应尽可能使用Array,无法确定数组大小时才使用ArrayList;
不过当试着解决更一般化的问题时,Array的功能就可能过于受限。

4.Array的操作
(1)Java中一切皆对象,Array也是对象。无论Array的类型为何,Array名称本身实际上是一个reference,指向heap之内某个实际对象。
(2)面对Array,我们可以直接持有基本类型的Array,也可以持久reference的Array;但是容器类仅能持有reference,若要将基本类型置于容器内,需要使用wrapper类;但是wrapper类使用起来可能不很容易上手,此外,基本类型的效率比起其它来说好太多。
(3)对数组的一些基本操作,像排序、搜索、比较是很常见的,因此在Java中提供了Arrays类协助这几个操作:sort()、binarySearch()、equals()、fill()、asList()等,不过Arrays类没有提供删除方法,而ArrayList中有remove()方法,不知道是否是不需要在Array中删除的原因(因为此时应该使用链表)。

5.ArrayList的使用
ArrayList的使用也很简单:产生ArrayList,利用add()将对象置入,利用get(i)配合索引值将它们取出。这一切就和Array的使用方式完全相同,只不过少了[]而已。

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

7.ArrayList是Array的复杂版本
ArrayList内部封装了一个Object类型的数组,从一般的意义来说,它和数组没有本质的差别,甚至于ArrayList的许多方法,如Index、IndexOf、Contains、Sort等都是在内部数组的基础上直接调用Array的对应方法。

8.ArrayList类型识别
ArrayList存入对象时,抛弃类型信息,所有对象屏蔽为Object,编译时不检查类型,但是运行时会报错。
ArrayList与数组的区别主要就是由于动态增容的效率问题了。

9.ArrayList与Array的相互转换
List的toArray与Arrays的asList方法

转载于:https://www.cnblogs.com/yuanfei1110111/p/10181860.html

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值