Java中的Set集合

Set接口是Java中一个用来存放对象容器,是一个无序、不可重复的集合,存放于java.util包中

HashSet 是 Set 接口的典型实现,大多数时候使用 Set 集合时都使用这个实现类。我们大多数时候说的set集合指的都是HashSet

HashSet 按照 Hash 算法来存储集合中的元素,因此具有很好的存取和查找性能

HashSet 具有以下特点:
①不能保证元素的排列顺序
②不可重复
③HashSet 不是线程安全的
④集合元素可以使 null

当向 HashSet 集合中存入一个元素时,HashSet 会调用该对象的 hashCode() 方法来得到该对象的 hashCode 值,然后根据hashCode 值决定该对象在 HashSet 中的存储位置。

首先需要导入Java中的java.util.HashSet包

import java.util.HashSet;

Set容器的定义

Set set=new HashSet()//也可以使用泛型来限制元素的类型
Set<String> set=new HashSet<String>()//我们一般推荐使用泛型
//也可以使用Object类
Set<Object> set=new HashSet<String>();

Set接口的一些重要的方法

  set.add(1);
  set.add("a");//添加元素
  System.out.println(set);
  
  set.remove(1);//移除元素
  System.out.println(set);
  
  set.clear();//清空集合
  System.out.println(set);
  
  set.add("a");
  set.add("b");
  set.add("c");
  set.add("d");
  
  set.add("d");//添加失败 set集合是不重复的
  System.out.println(set);
  
  //使用迭代器遍历集合
  Iterator it=set.iterator();
  System.out.println(it);
  while(it.hasNext()) {
      System.out.println(it.next());
  }
  
  //for each迭代集合
  for(Object obj:set) {//把set的每一个值取出来 赋值给obj 直到循环set的所有值
      System.out.println(obj);
  }
  
  System.out.println(set.size());//获得set的长度

TreeSet 是 SortedSet 接口的实现类,TreeSet 可以确保集合元素处于排序状态。
TreeSet 支持两种排序方法:自然排序和定制排序。默认情况下,TreeSet 采用自然排序。

  Set<Integer> set=new TreeSet<Integer>();
  
  set.add(5);
  set.add(2);
  set.add(4);
  set.add(6);
  set.add(1);
  set.add(8);
  System.out.println(set);
  
  set.remove(2);
  //判断集合中是否存在某个元素
  System.out.println(set.contains(3));
  
  //使用迭代器遍历集合
  Iterator<Integer> it=set.iterator();
  while(it.hasNext()) {
      System.out.println(it.next());
  }
  
  //for each类型迭代
  for(Object obj:set) {
      System.out.println(obj);
  }

需要注意的是,TreeSet必须使用同样类型的对象,否则会出现异常

结果的话大家可以copy到自己的集成开发环境中运行一下,多使用print方法查看结果,能够很快掌握Set集合以及TreeSet接口的使用方法

你可能感兴趣的:(Java,java)