因为Set接口继承Collection接口,它与List集合的区别就是:List集合可以保存重复的数据,而Set集合不可以。
此外,Set接口有三个常用实现类:
1.HashSet,特点:
- 它不按照存储的顺序保存,具有不确定性,也就是说每一次遍历集合出的元素排序不一定相同;
- 允许使用null元素
2.LinkedHashSet,特点:
- 它是HashSet的子类,但它却是按照自然顺序保存的(不是简单的线性顺序)
- 由于该实现类对象维护者一个运行于所有元素的双重链接列表,且该链接列表定义了一个迭代顺序(从名字上就可以看出Linked,被链接的,各个元素之间有一定的关系),
- 所以在遍历该实现类集合时按照元素的插入顺序进行遍历
3.TreeSet,特点:
- 及实现Set接口,也实现了SortedSet接口,具有排序功能
- 存入TreeSet中的对象元素需要实现Comparable接口
如下有一个set集合:
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
1.增强型for循环(for-each)
for(String name:names){
System.out.println(name);
}
2.迭代器遍历
Iterator<String> iterator = names.iterator();//<String>泛型
while(iterator.hasNext()){ //hasNext()用于判断是否含有下一个元素
System.out.println(iterator.next());//next()用于指向下一个元素
}