Set接口继承Collection接口,它与List集合有一个区别就是:List集合可以保存重复的数据,而Set集合不可以。Set接口有三个常用实现类:
- HashSet,特点:
- 它不按照存储的顺序保存,具有不确定性,也就是说每一次遍历集合出的元素排序不一定相同;
- 允许使用null元素
- LinkedHashSet,特点:
- 它是HashSet的子类,但它却是按照自然顺序保存的(不是简单的线性顺序)
- 由于该实现类对象维护者一个运行于所有元素的双重链接列表,且该链接列表定义了一个迭代顺序(从名字上就可以看出Linked,被链接的,各个元素之间有一定的关系),所以在遍历该实现类集合时按照元素的插入顺序进行遍历
- TreeSet
- 及实现Set接口,也实现了SortedSet接口,具有排序功能
- 存入TreeSet中的对象元素需要实现Comparable接口
让我们以HashSet实现类为例演示一下Set接口方法:
package gather;
import java.util.HashSet;
import java.util.Iterator;
import java.util.Set;//引包
public class Test{
public static void main(String[] args) {
Set<String> names = new HashSet<String>();//多态,<String>泛型,用于限制存入集合中的元素的数据类型
//add(Object element)用于向集合中添加元素,添加成功返回true,否则返回false
System.out.println(names.add("刘一"));//true
System.out.println(names.add("陈二"));//true
System.out.println(names.add("张三"));//true
System.out.println(names.add("张三"));//false
//size()用于返回集合中元素的个数
int size = names.size();
System.out.println(size);//3
//isEmpty()用于判断集合中是否含有元素,没有返回true,有返回false
boolean flag = names.isEmpty();
System.out.println(flag);//false
//remove(Object element)移除集合中指定的元素,删除成功返回true,否则返回false
System.out.println(names.remove("张三");//true
System.out.println(names.size());//2
//contains()用于判断集合中是否含有元素element,有则返回true,没有则返回false
System.out.println(names.contains("刘一"));//true
//遍历集合
//因为Set集合中的元素不是按照存储顺序保存的,所以每个元素也就没有索引,这也就说明了为什么Set集合中没有get方法,
//因此,对Set集合的遍历只能通过加强循环(for-each)和迭代器进行遍历
for(String name:names){
System.out.println(name);
}
//刘一 陈二 (不一定是这个顺序)
Iterator<String> iterator = names.iterator();//<String>泛型
while(iterator.hasNext()){ //hasNext()用于判断是否含有下一个元素
System.out.println(iterator.next());//next()用于指向下一个元素
}
//陈二 刘一 (不一定是这个顺序)
//clear()用于清空集合中所有的元素
names.clear();
System.out.println(names.size());//0
}
}