public class SetList {
public static void main(String[] args) {
Set<Integer> set =new TreeSet<Integer>();
List<Integer> list=new ArrayList<Integer>();
for(int i=-3;i<3;i++){
set.add(i);
list.add(i);
}
for(int i=0;i<3;i++){
set.remove(i);
list.remove(i);
}
System.out.println(set+" "+list);
}
}
输出结果为[-3, -2, -1] [-2, 0, 2]
原因是set.remove(i)调用了重载方法remove(E);
而list.remove(i)调用的是重载方法remove(int i).
还有这段代码都是重载惹的祸!
public class CollectionClassifier {
public static String classify(Set<?> s){
return "Set";
}
public static String classify(List<?> lst){
return "List";
}
public static String classify(Collection<?> c){
return "Collection";
}
public static void main(String[] args) {
Collection<?>[] collections={
new HashSet<String>(),
new ArrayList<Bigram>(),
new HashMap<String,String>().values()
};
for(Collection<?> c:collections){
System.out.println(classify(c));
}
}
}
本文摘自Effective Java中文版第二版!