66.asList方法产生的list对象不可更改
这里说的asList方法,是指Arrays工具类中的方法,与建议65相同
67.不同的列表选择不同的遍历方法
这里主要说的是foreach循环,与for循环的在实现了RandomAccess接口的对象上的效率差别。在Java中,RandomAccess和Cloneable、Serializable一样,都是标志性接口,不需要任何实现,只要用来表明其实现类具有某些特质的,实现了Cloneable接口表明可以被拷贝,Serializable可以被序列化,RandomAccess则表明这个类可以随机存取。
java中的foreach语法是Iterator(迭代器)的变形用法,书中通过对一个list求平均值来说明对列表使用恰当的遍历方法所带来的效率提升。如下:
pubic static int average(List<Integer> list){
int sum=0;
//可以随机存取,则使用下标遍历
if(list instanceof RandomAccess){
for(int i=0,size=list.size();i<size;i++){
sum+=list.get(i);
}
}else{
//有序存取,使用foreach
for(inti:list)
sum+=i;
}
}
return sum/list.size();
}
68.频繁删除和插入时使用LinkedList
双向链表
69.列表相等只需关心元素数据
例子:返回是true
public
static
void
main
(
String
[]
args
) {
ArrayList
<
String
> arrayList=
new
ArrayList
<
String
>();
arrayList.
add
(
"A"
);
Vector
<
String
> vector=
new
Vector
<
String
>();
vector.
add
(
"A"
);
System
.out.
println
(
"arrayList.equals vector?"
+arrayList.
equals
(vector));
}
java如此处理也确实是为开发者着考虑,列表只是一种容器,只要是同一种类型的容器(如List),不用关心容器的细节差别,(如ArrayList和LinkedList),只要确定所有的元素数据相等,那这两个列表就相等。如此一来,我们就不用太关注容器的细节,
其他的集合类型,如Set,map等与此相同,也只是关心集合元素,而不用考虑集合类型。
70.子列表,只是原列表的一个视图
List接口,提供了subList方法,其作用是返回一个列表的子列表,所有的修改动作直接作用于原列表
71.推荐使有subList处理局部列表
通过一个需求来说明:一个列表有100个元素,现在要删除索引20至30位置的元素
一般我们通过遍历也可以删除
//初始化一个固定长度,不可变列表
List
<
Integer
> data=
Collections
.nCopies(100, 0);
//转换为可变列表
List
<
Integer
> aList=
new
ArrayList
<
Integer
>(data);
//遍历,删除符合条件
for
(
int
i=0,size=data.size();i<size;i++){
if
(i>=20&&i<=30)
aList.remove(i);
}
但我们还可以直接通过subList来实现:
List
<
Integer
> bList=
new
ArrayList
<
Integer
>(data);
bList.subList(20, 30).clear();