Set集合的特点和应用

简介: 1.创建集合对象:Set<Student> set = new HashSet<>();2.分别创建五个Student对象3.使用add方法将Student对象添加到集合中4.使用选代器遍历集合并打印,注意添加顺序和打印顺序是否相同

四、 Set集合的特点和应用

  • Set集合的特点特点:不可重复、无序
  • 应用:Set set = new HashSet<>0;

4.案例: Set集合的简单使用

  • 4.1、需求:

向Set集合中添加五个元素,并遍历打印

  • 4.2、分析:

A. 向集合中添加元素的方法为: add()
B. 遍历集合的方式:选代器

  • 4.3、步骤:

1.创建集合对象:Set set = new HashSet<>();
2.分别创建五个Student对象
3.使用add方法将Student对象添加到集合中
4.使用选代器遍历集合并打印,注意添加顺序和打印顺序是否相同

4.4、创建学生实体类

import java.util.Objects;
public class Student {
    private String name;
    private Integer age;

    public Student() {}
    public Student(String name, Integer age) {
        this.name = name;
        this.age = age;
    }

    @Override
    public String toString() {
        return "Student{" + "name='" + name + '\'' + ", age=" + age + '}';
    }
    
    public String getName() {return name;}

    public void setName(String name) {this.name = name;}

    public Integer getAge() {return age;}

    public void setAge(Integer age) {this.age = age;}
}

4.5、创建测试类

import java.util.HashSet;
import java.util.Set;
public class Text {
    public static void main(String[] args) {
        //创建集合对象
        Set<Student> set = new HashSet<>();
        //创建对象
        Student student1 = new Student("张三",12);
        Student student2 = new Student("李四",26);
        Student student3 = new Student("李四",48);
        Student student4 = new Student("王五",35);
        Student student5 = new Student("张三",12);
        Student student6 = new Student("李四",26);
        //将集合对象添加到元素对象中
        set.add(student1);
        set.add(student2);
        set.add(student3);
        set.add(student4);
        set.add(student5);
        set.add(student6);
    }
}
==直接遍历循环==
        //直接遍历集合
        System.out.println(set);
==通过迭代器遍历集合==
        Iterator it = set.iterator();
        //判断迭代器是否有元素
        while (it.hasNext()){
            //如果有元素,就获取元素
            System.out.println(it.next());
        }
==通过增强for遍历Set集合==
        for (Student student:set){
            System.out.println(student);
        }

4.6、set集合一些问题

  • 遍历集合为什么Set集合没有"去重"?
    1.因为Set集合保证元素的唯一性依赖: equals()和hashCode ()两个方法。
    2.你没有在Student类中重写这两个方法,默认调用的是0bject类中的这两个方法。
    3.而Object类中的equals()方法默认比较的是地址值是否相
  • 解决方案:

               在Student实体类中重写equsls()和hashCode()方法.
           
    
 @Override
    public boolean equals(Object o) {
        if (this == o) return true;
        if (o == null || getClass() != o.getClass()) return false;
        Student student = (Student) o;
        return Objects.equals(name, student.name) && Objects.equals(age, student.age);
    }
    @Override
    public int hashCode() {
        return Objects.hash(name, age);
    }
相关文章
|
3月前
|
存储 NoSQL 关系型数据库
Redis 集合(Set)
10月更文挑战第17天
48 5
|
3月前
|
算法 Java 数据处理
从HashSet到TreeSet,Java集合框架中的Set接口及其实现类以其“不重复性”要求,彻底改变了处理唯一性数据的方式。
从HashSet到TreeSet,Java集合框架中的Set接口及其实现类以其“不重复性”要求,彻底改变了处理唯一性数据的方式。HashSet基于哈希表实现,提供高效的元素操作;TreeSet则通过红黑树实现元素的自然排序,适合需要有序访问的场景。本文通过示例代码详细介绍了两者的特性和应用场景。
53 6
|
3月前
|
存储 Java 数据处理
Java Set接口凭借其独特的“不重复”特性,在集合框架中占据重要地位
【10月更文挑战第16天】Java Set接口凭借其独特的“不重复”特性,在集合框架中占据重要地位。本文通过快速去重和高效查找两个案例,展示了Set如何简化数据处理流程,提升代码效率。使用HashSet可轻松实现数据去重,而contains方法则提供了快速查找的功能,彰显了Set在处理大量数据时的优势。
39 2
|
3月前
|
存储 算法 Java
解析HashSet的工作原理,揭示Set如何利用哈希算法和equals()方法确保元素唯一性,并通过示例代码展示了其“无重复”特性的具体应用
在Java中,Set接口以其独特的“无重复”特性脱颖而出。本文通过解析HashSet的工作原理,揭示Set如何利用哈希算法和equals()方法确保元素唯一性,并通过示例代码展示了其“无重复”特性的具体应用。
61 3
|
2月前
set集合
HashSet(无序,唯一): 基于 HashMap 实现的,底层采用 HashMap 来保存元素。 LinkedHashSet: LinkedHashSet 是 HashSet 的子类,并且其内部是通过 LinkedHashMap 来实现的。 TreeSet(有序,唯一): 红黑树(自平衡的排序二叉树)。
|
2月前
|
存储 Java
判断一个元素是否在 Java 中的 Set 集合中
【10月更文挑战第30天】使用`contains()`方法可以方便快捷地判断一个元素是否在Java中的`Set`集合中,但对于自定义对象,需要注意重写`equals()`方法以确保正确的判断结果,同时根据具体的性能需求选择合适的`Set`实现类。
|
2月前
|
存储 Java 开发者
在 Java 中,如何遍历一个 Set 集合?
【10月更文挑战第30天】开发者可以根据具体的需求和代码风格选择合适的遍历方式。增强for循环简洁直观,适用于大多数简单的遍历场景;迭代器则更加灵活,可在遍历过程中进行更多复杂的操作;而Lambda表达式和`forEach`方法则提供了一种更简洁的函数式编程风格的遍历方式。
|
2月前
|
Java 开发者
|
3月前
|
存储 Java 数据处理
Set 是 Java 集合框架中的一个接口,不包含重复元素且不保证元素顺序。
【10月更文挑战第16天】Java Set:无序之美,不重复之魅!Set 是 Java 集合框架中的一个接口,不包含重复元素且不保证元素顺序。通过 hashCode() 和 equals() 方法实现唯一性,适用于需要唯一性约束的数据处理。示例代码展示了如何使用 HashSet 添加和遍历元素,体现了 Set 的高效性和简洁性。
51 4
|
3月前
|
存储 Java 数据处理
Set 是 Java 集合框架中的一个接口,不包含重复元素且不保证元素顺序。
Java Set:无序之美,不重复之魅!Set 是 Java 集合框架中的一个接口,不包含重复元素且不保证元素顺序。它通过 hashCode() 和 equals() 方法确保元素唯一性,适用于需要唯一性约束的数据处理。示例代码展示了如何使用 HashSet 实现这一特性。
42 5