Collection 接口
- Set: 元素无序,不可重复的集合 ----类似高中的“集合”
- List: 元素有序,可重复的集合 —”动态”数组
Collection 接口继承树
Collection 接口方法
- size():返回集合中元素的个数
- add(Object obj):向集合中添加一个元素
- addAll(Collection coll):将形参coll中包含的所有元素添加到当前集合中
- isEmpty():判断集合是否为空
- clear():清空集合元素
- contains(Object obj):判断集合中是否包含指定的obj元素。如果包含,返回true,反之返回false
- 判断的依据:根据元素所在的类的equals()方法进行判断(String类)
- 明确:如果存入集合中的元素是自定义类的对象。要求:自定义类要重写equals()方法
- containsAll(Collection coll):判断当前集合中是否包含coll中所有的元素
- retainAll(Collection coll):求当前集合与coll的共有的元素,返回给当前集合
- remove(Object obj):删除集合中的obj元素。若删除成功,返回true.否则,返回false
- removeAll(Collection coll):从当前集合中删除包含在coll中的元素。
- equals(Object obj):判断集合中的所有元素是否完全相同
- toArray():将集合转换成数组
- iterator():返回一个Iterator接口实现类的对象,进而实现集合的遍历(三个方式)
注意:
这些方法完全来自 Java API 文档,读者可以自行参考 API 文档来查阅这些方法的详细信息。实际上,读者无需硬性记忆这些方法,只要牢记一点:集合类就像容器,现实生活中容器的功能,无非及时添加对象、删除对象、清空对象、判断容器是否为空等。集合类就为这些功能提供了对应的方法。
摘自《疯狂的Java讲义》
注意:
@Test
public void TestCollection2() {
Collection<Object> coll = new ArrayList<>();
coll.add(new Person("MM", 23));
boolean b2 = coll.contains(new Person("MM", 23));
System.out.println(b2);
//若没重写自定义类的equals()方法,则为false
集合的遍历
Collection<Object> coll = new ArrayList<>();
coll.add(123);
coll.add(new String("AA"));
coll.add(new Date());
coll.add("BB");
coll.add(new Person("MM", 23));
//正确的方式
Iterator<Object> i = coll.iterator();
while(i.hasNext()){
System.out.println(i.next());
}
//错误的方式
while((i.next()) != null){
//java.NoSuchElementException
System.out.println(i.next());
}
注意:
- i.hasNext():判断下一个位置是否有值
- i.next():一方面打印下一位的值;另一方面指针下移一位
使用增强for循环遍历
//使用增强for循环实现集合的遍历
@Test
public void testFor(){
Collection<Object> coll = new ArrayList<>();
coll.add(123);
coll.add(new String("AA"));
coll.add(new Date());
coll.add("BB");
coll.add(new Person("MM", 23));
//每次coll中取一个元素赋给0
for(Object o : coll){
//此处的o是新定义的局部变量,其值的修改不会对coll本身造成影响
System.out.println(o);
}
}