一、集合与数组之间的相互转换
1、数组转集合:
使用数组工具类Arrays中的asList()方法来实现。
例:
String[] stringArray = {"haha","xixi","hehe"};
方式一:
List<String> list = Arrays.asList(stringArray);
方式二:
List<String> list = Arrays.asList("haha","xixi","hehe");
注意:
方式一只对引用数据类型的数组有效,对于基本数据类型数组(如int[])只能使用方式二的
形式。
使用asList方法得到的集合,元素列表长度是固定,不能对其进行增删操作,否则会报异常
,但是可以对元素修改。
2、集合转数组:
使用Collection中的toArray()或toArray(T[] a)方法来实现。
空参方法:
该方法返回的是一个对应的Object[]类型的数组。
Object[] array = list.toArray();
带参方法:
该方法返回 包含 此集合中所有元素的数组。
String[] array = list.toArray(new String[0]);
方法过程:首先,list会试图将所有元素存进作为参数传入的数组(new String[0])内,
当参数数组长度不够时,系统会自动分配一个长度和类型与list相同的数组容
纳list的元素,最后该方法的返回值为一个包含list中所有元素的数组;
即:{"haha","xixi","hehe"};
当参数数组长度大于list长度时,数组的剩余空间将自动被null所填充,此时该
方法的返回值为长度和内容与参数数组相同的数组。
如:{"haha","xixi","hehe",null,null};
所以,通常情况下new一个长度为0的对应类型数组传入即可。
二、ArrayList与数组的区别
数组和ArrayList在用法上有很多相似之处,比如都可以通过索引角标对元素进行查找或修改修改操作。
但两者之间的最大区别在于数组的长度是固定的,而集合的长度是可以动态变化的。
数组无法做到真正意义上的增删元素操作,而ArrayList可以。当ArrayList从列表中删除元素时,后面的
元素会自动向前移动填充空位,索引也随之发生变化。
另外ArrayList可以存放不同数据类型的元素,而数组只能储存同一类型的元素。
三、Collection和Collections的区别
Collection与Collections的区别就相当于汽车和汽水的区别,两者除了都与集合相关之外再没有其他共同点。
Collection是一个接口,是所有集合类的父级接口,它的直接继承接口有List、Set和Queue。
Collections是专门为集合类所定义的一个工具类,它提供了许多静态方法供我们在操作集合时使用,如
swap(),addAll(),sort()等等。
四、遍历集合的方式
1、foreach方式:
例:for(String str : list){
System.out.println(str);
}
优点:使用方便。
缺点:只能遍历,不能做其他操作。
2、for循环方式:
例:for(int i = 0 ; i < list.size() ; i++) {
system.out.println(list.get(i));
}
优点:效率较高。
缺点:适用范围太窄,基本只供ArrayList使用。LinkedList可以使用但不建议使用,遍历效率非常低。
3、iterator方式
例:Iterator it = list.iterator();
while(it.hasNext()){
System.out.println(it.next());
}
优点:迭代器提供了方法可以在遍历时对集合进行删除操作(it.remove())。
缺点:运行复杂,性能一般,效率一般。
注意:在一次循环内调用两次remove()方法,或者在没有调用next()方法的情况下调用了remove()
方法会导致程序抛异常。
五、CopyOnWriteArrayList——ArrayList的线程安全的变体
1,AbstractList :
该类是一个抽象类,为其他list接口提供了很多方法的实现,如果需要定义一个List实现类,可以继承
该类。
2,CopyOnWriteArrayList:
该类是ArrayList 的一个 线程安全的变体,其中所有可变操作(add、set 等等)都是通过对底层数组进
行一次新的复制来实现的。
这一般需要很大的开销,但是当遍历操作的数量大大超过可变操作的数量时,这种方法可能比其他替代方
法更有效;在不能或不想进行同步遍历,但又需要从并发线程中排除冲突时,它也很有用。