java中array,arrayList区别

本文对比了Java中数组和List的不同特性,详细介绍了ArrayList作为自动扩容数组的实现原理及其操作成本,同时阐述了LinkedList作为双向链表的优势及不足,并提供了两者间的转换方法。
1.Java中的数组

1.数组在内存中是连续存储的,索引速度非常快,赋值和修改元素比较简单;

2.声明数组的时候,必须制定数组的长度,数组的长度过长,会内存浪费,过短会数据溢出的错误;

3.数组只允许存放一种数据类型

2.List

List是接口,与set一样继承子集合类Colllection接口,提供了按索引访问的方式。有两个实现分别是ArrayList和LinkedList

1>ArrayList

    可以看做容量自动增长的数组,底层是使用数组来实现的,使用不带参数的构造方法构造一个List时,默认会在底层生成一个长度是10的数组;

List<String> list = new ArrayList<>();

如果后续元素继续增长,超过大小之后,ArrayList会在底层生成一个新的数组,大小是=原来大小*1.5+1,然后将原数组的内容复制进去;当新的数组长度不够时,重复该过程;

2>对于ArrayList的删除操作,需要被删除的元素向前移动,代价比较大

3>集合当中只能放对象的引用,无法放置原生数据类型,所以必须使用原生数据的包装类才可以加到集合当中;下面的代码就是错误的,无法放置原生基本类型到集合中

List<int> list1 = new ArrayList<>();

4>LinkedList:是一个双向链表,添加和删除元素时比ArrayList性能更好,但是在索引数据的时候,若于ArrayList,因为需要从链表头开始往后一个一个查找;Array获取数据的时间复杂度是o(1),LinkedList索引数据的时间复杂度为o(N);另外linkedList需要更多的内存,因为ArrayList每个节点存储的是实际数据和前后节点的位置;

3.两者互相转换

1>数组转换为List

String[] array = new String[]{"aa", "bb", "cc"};
List<String> strings = Arrays.asList(array);

使用Arrays.asList来转换;

2>List转换为数组

List<String> strings = Arrays.asList(array);
String[] objects = (String[]) strings.toArray();

使用数组.toArray()来转换





### JavaArrayList Array 的对比 #### 数据结构定义 在 Java 中,`Array` 是一种基本的数据存储形式,而 `ArrayList` 则是基于数组实现的一种动态集合类。`Array` 需要在创建时指定长度,并且其大小不可变[^4]。相比之下,`ArrayList` 提供了一种更灵活的方式管理数据集,允许动态调整容量。 #### 类型支持 `Array` 可以保存原始类型(如 `int`, `char` 等),也可以保存对象类型的引用。然而,`ArrayList` 仅能保存对象类型的引用,无法直接存储原始类型。为了弥补这一不足,Java 提供了自动装箱/拆箱机制来处理原始类型到对应包装器类的转换[^2]。 #### 大小灵活性 `Array` 的尺寸一旦设定便不可更改。如果尝试向已满的数组中添加新元素,则会抛出异常或者需要手动复制到更大的数组中完成扩展。与此不同的是,当 `ArrayList` 达到当前容量上限时,它能够自动增加内部数组的大小以容纳更多项[^1]。 #### 性能考量 对于频繁访问操作而言,由于底层均采用连续内存布局的缘故,两者表现相似——随机存取时间复杂度均为 O(1)[^4]。但在涉及大量增删动作的情况下,尤其是中间位置上的变动,`ArrayList` 可能因为每次扩容都需要重新分配空间以及移动现有记录而导致效率下降;而对于固定规模的任务来说,原生 `Array` 往往具备更高的执行速度与更低的空间开销。 以下是将 `Array` 转换为 `ArrayList` 并再次还原成 `Array` 的简单示例: ```java import java.util.ArrayList; import java.util.Arrays; public class Test { public static void main(String[] args) { String[] array = {"A", "B", "C"}; // 将数组转化为列表 ArrayList<String> list = new ArrayList<>(Arrays.asList(array)); System.out.println("List after conversion: " + list); // 修改列表中的某个值 if (!list.isEmpty()) { list.set(0, "Modified"); } System.out.println("Updated List: " + list); // 把列表再转回数组 String[] newArray = list.toArray(new String[0]); System.out.println("New Array content: " + Arrays.toString(newArray)); } } ``` 此代码片段展示了如何利用 `Arrays.asList()` 方法快速构建一个初始状态固定的列表实例,随后通过新建一个可变版本 (`new ArrayList<>`) 来获得完全可控的操作权限^3]。 综上所述,在实际开发过程中应依据具体需求权衡选用合适的数据容器形式。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值