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接口的使用方法

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
JavaSet是一种集合类型,它不允许重复元素,并且没有固定的顺序。常见的Set实现类有HashSet、LinkedHashSet和TreeSet。下面是Set的用法示例: 1. 创建Set对象 可以使用以下语法创建Set对象: ```java Set<T> set = new HashSet<>(); // 创建HashSet对象 Set<T> set = new LinkedHashSet<>(); // 创建LinkedHashSet对象 Set<T> set = new TreeSet<>(); // 创建TreeSet对象 ``` 其,T表示元素的类型。 2. 添加元素 可以使用add()方法向Set添加元素: ```java set.add(element); // 将元素添加到Set,如果Set已经存在该元素,add()方法不会执行任何操作 ``` 3. 删除元素 可以使用remove()方法从Set删除元素: ```java set.remove(element); // 从Set删除指定元素,如果Set不存在该元素,remove()方法不会执行任何操作 ``` 4. 判断元素是否存在 可以使用contains()方法判断Set是否存在指定元素: ```java set.contains(element); // 如果Set存在该元素,返回true;否则返回false ``` 5. 遍历元素 可以使用foreach循环或者迭代器遍历Set的元素: ```java for (T element : set) { // 对元素进行操作 } Iterator<T> iterator = set.iterator(); while (iterator.hasNext()) { T element = iterator.next(); // 对元素进行操作 } ``` 6. 获取元素个数 可以使用size()方法获取Set元素的个数: ```java set.size(); // 返回Set元素的个数 ``` 7. 清空Set 可以使用clear()方法清空Set的所有元素: ```java set.clear(); // 清空Set的所有元素 ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值