Set集合常用方法 && 遍历Set集合的方法

Set接口继承Collection接口,它与List集合有一个区别就是:List集合可以保存重复的数据,而Set集合不可以。Set接口有三个常用实现类:

  1. HashSet,特点:
  • 它不按照存储的顺序保存,具有不确定性,也就是说每一次遍历集合出的元素排序不一定相同;
  • 允许使用null元素
  1. LinkedHashSet,特点:
  • 它是HashSet的子类,但它却是按照自然顺序保存的(不是简单的线性顺序)
  • 由于该实现类对象维护者一个运行于所有元素的双重链接列表,且该链接列表定义了一个迭代顺序(从名字上就可以看出Linked,被链接的,各个元素之间有一定的关系),所以在遍历该实现类集合时按照元素的插入顺序进行遍历
  1. 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
	}
}
发布了34 篇原创文章 · 获赞 8 · 访问量 698

猜你喜欢

转载自blog.csdn.net/weixin_45720626/article/details/105489010