刚开始学习Java,一直对String[]和List<String>的区别不太清楚,针对此问题做一个总结。
典型的区别是,String[]数组里面存放的String类型的值,List<String>存放的String类型的对象。
数组的容量是固定的,只能一次获取或者设置一个元素的值,而ArrayList和List<T>的容量可以根据需要自动扩充、修改、删除或者插入数据。
数组可以具有多个维度,而List<T>始终只具有一个维度。
String[]是 数组,定长,不可变,List<String> 是泛型 ,非定长,可变。
作用是一样的,但灵活性不同。String[]是定长的,不容易实现容量增长、中间插入一个字符串这样的操作,List<String>则可以方便实现。如果你能确定字符串数组长度,而且可以逐项填充的话,建议用String[]。如果不能确定数组长度,或者在计算值时需要不断向中间插入一个字符串,可以使用List<String>,生成完成后再用ToArray()方法转换为String[],String[]也可以通过List的AddRange方法添加到List<String>。
特定类型(Object 除外)的数组 的性能优于List的性能。这是因为 List的元素属于 Object 类型;所以在存储或检索值类型时通常发生装箱和取消装箱操作。不过,在不需要重新分配时(即最初的容量十分接近列表的最大容量),List< T> 的性能与同类型的数组十分相近。
数组
数组是在内存中连续存储的,所以索引速度非常快,赋值和修改比较简单。
//声明数组
string[] str = new string[2];
//声明数组并赋值
string[] str = { "a", "b" };
//赋值
str[0] = "a";
str[1] = "b";
//修改
str[1] = "c";
但是数组在声明时需要指定数组的长度,长度过长会造成内存浪费,过短会造成数据溢出,如果声明时不清楚数组的长度就会比较麻烦,另外在数组中插入数据比较麻烦。
ArrayList
//声明
ArrayList arrayList = new ArrayList();
//新增
arrayList.Add("a");
arrayList.Add("b");
arrayList.Add(123);
//插入指定索引位置数据
arrayList.Insert(0, 123);
//修改指定索引位置数据
arrayList[2] = 234;
//删除匹配数据
arrayList.Remove("a");
//删除指定索引数据
arrayList.RemoveAt(1);
在arrayList中,不仅插入了字符串a,还插入了数字123。这样在ArrayList中插入不同类型的数据是允许的。ArrayList会把所有插入其中的数据当作为object类型来处理,在使用ArrayList处理数据时,可能会报类型不匹配,也就是ArrayList不是类型安全的。在存储或检索值类型时通常发生装箱和取消装箱操作,带来很大的性能耗损。
装箱与拆箱的概念
装箱:就是将值类型的数据打包到引用类型的实例中。
比如将string类型的值a赋给object对象obj
拆箱:就是从引用数据中提取值类型。
比如将object对象obj的值赋给string类型的变量str。
//装箱
string str = "a";
object obj = (object)str;
//封箱
object obj = "a";
string str = (string)obj;
List
在声明List集合时,我们同时需要为其声明List集合内数据的对象类型。
//声明
List<string> list = new List<string>();
//新增
list.Add("a");
list.Add("b");
//修改
list[0] = "c";
//移除指定匹配项
list.Remove("a");
//移除对应索引值
list.RemoveAt(0);
String[]和List<String>的互换
String[]转List:
List list = Arrays.asList(arr);
List转String[]:
String[] arr = list.toArray(new String[list.size()]);
占个楼
厉害!!