一、 集合类体系结构
在接下来的学习中,会先学接口,在使用的时候会使用具体的实现类 在List接口下,之前学习了ArrayList集合,想回顾的请点击ArrayList集合 在集合的学习中主要学习List接口下的LinkedList、Set接口下的HashSet和TreeSet、 Map接口下的HashMap 接下来的先讲讲Collection接口
二、Collection集合的概述
想学习Collection集合接口,我们可以通过查询帮助文档去学习 通过查询帮助文档 public interface Collection extends Iterable 集合层次结构中的根界面。 集合表示一组被称为其元素的对象。 一些集合允许重复元素,而其他集合不允许。 有些被命令和其他无序。 JDK不提供此接口的任何直接实现:它提供了更具体的子接口的实现,如Set和List 。 该界面通常用于传递集合,并在需要最大的通用性的情况下对其进行操作。 也就是说Collection这接口并没有具体的实现类,这个想要实现,必须通过Set或者List的实现类来实现对象
创建Collection集合对象
package MyCollection;
import java.util.ArrayList;
import java.util.Collection;
public class CollectionDemo {
public static void main(String[] args) {
Collection<String> c = new ArrayList<>();
c.add("Hello");
c.add("World");
System.out.println(c);
}
}
通过观察输出结果我们可以看到,直接输出打印c并没有输出包名和c的地址,所以可见,Collection接口已经将toString重写
三、Collection集合常用方法
方法名 | 说明 |
---|
boolean add(E e) | 添加元素 | boolean remove(Object o) | 从集合中移除指定元素 | void clear() | 清空集合中的元素 | boolean contains(Object o) | 判断集合中是否存在指定元素 | boolean isEmpty( ) | 判断集合是否为空 | int size( ) | 集合长度,也就是集合中元素的个数 |
1、add——添加元素
package MyCollection;
import java.util.ArrayDeque;
import java.util.Collection;
public class AddDemo {
public static void main(String[] args) {
Collection<String> c = new ArrayDeque<String>();
System.out.println(c.add("Hello"));
System.out.println(c.add("World"));
System.out.println(c);
}
}
调用add方法会返回true 那么是不是一定都是返回true呢? 答案是肯定的 通过查询add方法的源码
public boolean add(E e) {
addLast(e);
return true;
}
可以看到,无论添加什么内容,最后都会return true
2、remove——移除指定元素
package MyCollection;
import java.util.ArrayDeque;
import java.util.Collection;
public class RemoveDemo {
public static void main(String[] args) {
Collection<String> c = new ArrayDeque<String>();
c.add("Hello");
c.add("World");
System.out.println(c);
System.out.println(c.remove("Hello"));
System.out.println(c.remove("java"));
System.out.println(c);
}
}
删除存在的元素会返回true, 删除不存在的元素会返回false
3、clear——清空集合中所有元素
package MyCollection;
import java.util.ArrayList;
import java.util.Collection;
public class ClearDemo {
public static void main(String[] args) {
Collection<String> c = new ArrayList<String>();
c.add("Hello");
c.add("World");
System.out.println(c);
c.clear();
System.out.println(c);
}
}
4、contains——判断集合是否存在某个元素
package MyCollection;
import java.util.ArrayList;
import java.util.Collection;
public class ContainsDemo {
public static void main(String[] args) {
Collection<String> c = new ArrayList<String>();
c.add("Hello");
c.add("World");
System.out.println(c.contains("Hello"));
System.out.println(c.contains("java"));
}
}
5、 isEmpty——判断集合是否为空
package MyCollection;
import java.util.ArrayList;
import java.util.Collection;
public class IsEmptyDemo {
public static void main(String[] args) {
Collection<String> c = new ArrayList<String>();
System.out.println(c.isEmpty());
c.add("Hello");
System.out.println(c.isEmpty());
}
}
6、size——集合长度
package MyCollection;
import java.util.ArrayList;
import java.util.Collection;
public class SizeDemo {
public static void main(String[] args) {
Collection<String> c = new ArrayList<String>();
c.add("Hello");
c.add("World");
System.out.println(c.size());
}
}
四、Collection集合的遍历
集合的遍历,顾名思义就是将集合的各个元素都按顺序读取一遍,可以将它们输出,这操作和数组的遍历大同小异,只不过需要集合要实现该功能需要调用一些特定的方法 在集合的遍历中,需要用到一个新东西——迭代器,集合的专门遍历方式
- Iterator < E > iterator( ):返回该集合中元素的迭代器,通过集合的iterator()方法得到
- 迭代器是通过集合的iterator()方法得到的,所有我们说它是以来集合而存在的
Iterator中常用方法
- E next():返回迭代中的下一个元素
- boolean hasNext():如果迭代具有更多元素,则返回true,常用来防止遍历出界
package MyCollection;
import java.util.ArrayList;
import java.util.Collection;
import java.util.Iterator;
public class IteratorDemo {
public static void main(String[] args) {
Collection<String> c = new ArrayList<String>();
c.add("Hello");
c.add("World");
Iterator<String> it = c.iterator();
while (it.hasNext()){
System.out.println(it.next());
}
}
}
接下来的其他集合的接口说明将会在后面的文章更新,敬请期待!!!!
|