java 列表、集合与数组之间的转化

package test;

import java.util.ArrayList;

import java.util.Arrays;

import java.util.HashSet;

import java.util.List;

import java.util.Set;

public class Test2 {
	public static void main(String[] args) {

		List list = new ArrayList();

		list.add("a");

		list.add("b");

		list.add("c");

		list.add("d");

		// list.add(1);//会产生java.lang.ArrayStoreException异常

		// 当list中的数据类型都一致时可以将list转化为数组

		Object[] array = list.toArray();

		System.out.println("从list转换成的对象数组长度为:" + array.length);

		// 在转化为其它类型的数组时需要强制类型转换,并且,要使用带参数的toArray方法,参数为对象数组,

		// 将list中的内容放入参数数组中,当参数数组的长度小于list的元素个数时,会自动扩充数组的长度以适应list的长度

		String[] array1 = (String[]) list.toArray(new String[0]);

		System.out.println("从list转换成的字符串数组长度为:" + array1.length);

		// 分配一个长度与list的长度相等的字符串数组

		String[] array2 = (String[]) list.toArray(new String[list.size()]);

		System.out.println("从list转换成的字符串数组长度为:" + array2.length);

		list.clear();

		// 将数组转换成list

		for (int i = 0; i < array.length; i++) {

			list.add(array[i]);

		}

		System.out.println("将数组转换成list的元素个数为:" + list.size());

		list.clear();

		// 直接使用Arrays的asList方法

		list = Arrays.asList(array);

		System.out.println("将数组转换成list的元素个数为:" + list.size());

		Set set = new HashSet();

		set.add("a");

		set.add("b");

		// 将set转换为数组

		array = set.toArray();

		array1 = (String[]) set.toArray(new String[0]);

		array2 = (String[]) set.toArray(new String[set.size()]);

		System.out.println("从Set转换成的对象数组长度为:" + array.length);

		System.out.println("从Set转换成的字符串数组长度为:" + array2.length);

		// 数组转换成Set

		// 将数组转换成List后,再用List构造Set

		set = new HashSet(Arrays.asList(array));

		System.out.println("将数组转换成Set的元素个数为:" + list.size());

		// 将Set清空,然后把数组转换成的list全部add

		set.clear();

		set.addAll(Arrays.asList(array1));

		System.out.println("将数组转换成Set的元素个数为:" + list.size());

	}

}

### Java 集合框架数组的使用场景及区别 #### 1. 基本概念 Java 中的数组是一种固定大小的数据结构,一旦创建其长度就无法改变。而集合则是动态可扩展的数据结构,能够根据需求自动调整容量[^1]。 #### 2. 定义方式 数组通过指定类型的方括号语法来声明并初始化,例如 `int[] numbers = new int[5];` 表明这是一个整型数组,初始大小为 5。相比之下,集合则依赖于接口和实现类,比如 `List<Integer> list = new ArrayList<>();` 这里我们使用的是泛型机制,允许存储任意类型的对象实例[^2]。 #### 3. 大小灵活性 由于数组尺寸固定,在运行期间如果需要增加更多元素就必须重新分配更大的空间并将原内容复制过去;然而集合内部实现了扩容逻辑,当达到当前容量上限时会自行处理增长过程。 #### 4. 类型支持 传统上讲,原始数据类型可以直接存入到数组当中,但是这些基本类型不能直接放进集合容器里面——除非先将其封装成对应的包装器类(Wrapper Class),如把 int 转化成为 Integer 对象后再加入列表之中。 #### 5. 功能特性对比 - **性能表现**: 访问特定索引位置上的项目或者迭代整个序列方面,两者都提供了O(1)时间复杂度的操作效率。不过涉及到频繁增删中间节点的情况,则链表形式的LinkedList可能优于ArrayList因为后者每次执行此类动作都需要移动后续部分从而耗费额外开销。 - **线程安全性**: 标准版本下的大多数集合都不是同步化的(synchronized),这意味着多线程环境下如果不采取适当措施可能会引发并发修改异常等问题。而对于简单的一维或多维静态布局来说,数组天然具备一定程度的安全保障[^3]。 - **继承关系&方法多样性**: Collection 接口派生出了多个子集接口及其具体实现类,形成了丰富的层次体系图谱,每一种都有独特的功能侧重方向满足不同业务需求。此同时还配套了一系列工具辅助类Collections提供诸如排序、查找等功能便捷调用。 ```java // 数组示例 String[] arrayExample = {"apple", "banana"}; // 集合示例 import java.util.ArrayList; import java.util.List; public class Main { public static void main(String[] args){ List<String> collectionExample = new ArrayList<>(); collectionExample.add("orange"); System.out.println(collectionExample.get(0)); // 输出 orange } } ```
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值