Java集合之Set(超详细)

简介: Set接口:存储无序、不可重复的数据 (类似于高中讲的集合)HashSet:作为Set接口的主要实现类;线程不安全;可以存储null值LinkHashSet:作为HashSet的子类;遍历其内部数据时,可以按照添加的顺序输出TreeSet:可以按照添加对象的指定属性进行排序
🏠个人主页: 黑洞晓威
🧑个人简介:大家好,我是晓威,一名普普通通的大二在校生,希望在CSDN中与大家一起成长。

🎁如果你也在正在学习Java,欢迎各位大佬来到我的博客查漏补缺呀,如果有哪里写的不对的地方也欢迎诸佬指正啊。

1,Set接口的框架

Collection接口:单列集合,用来存储一个一个的对象

  • Set接口:存储无序、不可重复的数据 (类似于高中讲的集合)

    • HashSet:作为Set接口的主要实现类;线程不安全;可以存储null值
    • LinkHashSet:作为HashSet的子类;遍历其内部数据时,可以按照添加的顺序输出
    • TreeSet:可以按照添加对象的指定属性进行排序

Set:存储无序的、不可重复的数据

  1. 无序性:不等于随机性。存储的数据在底层数组中并非按照数组的索引顺序添加,而是根据数据的哈希值对应数组的位置添加
  2. 不可重复性:保证添加的元素按照equals()判断时,不能返回true。即相同的元素只能添加一个。
保证元素不可重复需要让元素重写两个方法:一个是 hashCode(),另一个是 equals()。HashSet在存储元素的过程中首先会去调用元素的hashCode()值,看其哈希值与已经存入HashSet的元素的哈希值是否相同,如果不同 :就直接添加到集合;如果相同 :则继续调用元素的equals() 和哈希值相同的这些元素依次去比较。如果说有返回true的,那就重复不添加;如果说比较结果都说false,那就是不重复就添加。

2,HashSet

public static void main(String[] args) {
    HashSet set = new HashSet();
    set.add(123);
    set.add(456);
    set.add("AA");
    set.add(new Student("张三",18));

    System.out.println(set);
}
结果:

[AA, Student{name='张三', age=18}, 456, 123]

3,LinkedHashSet

LinkedHashSet作为HashSet的子类,在添加数据的同时,每个数据还维护了两个引用,记录数据的前一个数据与后一个数据
public static void main(String[] args) {
    HashSet set = new LinkedHashSet();
    set.add(123);
    set.add(456);
    set.add("AA");
    set.add(new Student("张三",18));

    System.out.println(set);
}
结果:

[123, 456, AA, Student{name='张三', age=18}]

可以看到LinkHashSet可以按顺序输出

4,TreeSet

方式一:自然排序

让元素所在的类实现Comparable接口,并重写CompareTo() 方法,并根据CompareTo()的返回值来进行添加元素

//所在类实现Comparable接口,并重写CompareTo() 方法
@Override
public int compareTo(Object o) {
    if (o instanceof Student){//判断类型是否为Student类的实例
        Student student =(Student) o;//转化为Student类型
        if(Integer.compare(this.age,student.age)!=0) {
            return Integer.compare(this.age,student.age);//年龄由小到大
        }else return this.name.compareTo(student.name);//名字由小到大
    }
}
方式二: 定制排序

使用TreeSet的有参构造方法创建TreeSet对象的时候, 传入一个比较器 Comparator 进去, TreeSet在添加元素的时候, 根据比较器的compare()方法的返回值来添加元素。

public static void main(String[] args) {
    TreeSet treeSet = new TreeSet();
    treeSet.add(new Student("张三",18));
    treeSet.add(new Student("李四",17));
    treeSet.add(new Student("王五",18));
    System.out.println(treeSet);
    Iterator iterator = treeSet.iterator();
    while (iterator.hasNext()){
        System.out.println(iterator.next());
    }


    //实例化Comparator
    Comparator comparator = new Comparator() {
        @Override
        public int compare(Object o1, Object o2) {
            if(o1 instanceof Student && o2 instanceof Student){
                Student s1 = (Student) o1;
                Student s2 = (Student) o2;
                int age = Integer.compare(s1.getAge(),s2.getAge());
                if(age!=0){
                    return -age;//按年龄从大到小
                }else return s1.getName().compareTo(s2.getName());
            }else throw new RuntimeException();
        }

        @Override
        public boolean equals(Object obj) {
            return false;
        }
    };

    TreeSet treeSet1 = new TreeSet(com);
    treeSet1.add(new Student("张三",18));
    treeSet1.add(new Student("李四",17));
    treeSet1.add(new Student("王五",16));
    System.out.println(treeSet1);


};
🎉文章到这里就结束了,感谢诸佬的阅读。🎉

💕欢迎诸佬对文章加以指正,也望诸佬不吝点赞、评论、收藏加关注呀😘在这里插入图片描述

相关文章
|
13天前
|
存储 NoSQL 关系型数据库
Redis 集合(Set)
10月更文挑战第17天
28 5
|
14天前
|
存储 Java
深入探讨了Java集合框架中的HashSet和TreeSet,解析了两者在元素存储上的无序与有序特性。
【10月更文挑战第16天】本文深入探讨了Java集合框架中的HashSet和TreeSet,解析了两者在元素存储上的无序与有序特性。HashSet基于哈希表实现,添加元素时根据哈希值分布,遍历时顺序不可预测;而TreeSet利用红黑树结构,按自然顺序或自定义顺序存储元素,确保遍历时有序输出。文章还提供了示例代码,帮助读者更好地理解这两种集合类型的使用场景和内部机制。
33 3
|
14天前
|
存储 Java 数据处理
Java Set接口凭借其独特的“不重复”特性,在集合框架中占据重要地位
【10月更文挑战第16天】Java Set接口凭借其独特的“不重复”特性,在集合框架中占据重要地位。本文通过快速去重和高效查找两个案例,展示了Set如何简化数据处理流程,提升代码效率。使用HashSet可轻松实现数据去重,而contains方法则提供了快速查找的功能,彰显了Set在处理大量数据时的优势。
26 2
|
14天前
|
Java
在Java的世界里,Set只接纳独一无二的元素。
【10月更文挑战第16天】在Java的世界里,Set只接纳独一无二的元素。本文通过拟人化的手法,讲述了重复元素从初次尝试加入Set被拒绝,到经历挣扎、反思,最终通过改变自己,成为独特个体并被Set接纳的全过程。示例代码展示了这一过程的技术实现。
24 1
|
11天前
|
安全 Java 程序员
深入Java集合框架:解密List的Fail-Fast与Fail-Safe机制
本文介绍了 Java 中 List 的遍历和删除操作,重点讨论了快速失败(fail-fast)和安全失败(fail-safe)机制。通过普通 for 循环、迭代器和 foreach 循环的对比,详细解释了各种方法的优缺点及适用场景,特别是在多线程环境下的表现。最后推荐了适合高并发场景的 fail-safe 容器,如 CopyOnWriteArrayList 和 ConcurrentHashMap。
39 5
|
12天前
|
安全 Java 程序员
Java集合之战:ArrayList vs LinkedList,谁才是你的最佳选择?
本文介绍了 Java 中常用的两个集合类 ArrayList 和 LinkedList,分析了它们的底层实现、特点及适用场景。ArrayList 基于数组,适合频繁查询;LinkedList 基于链表,适合频繁增删。文章还讨论了如何实现线程安全,推荐使用 CopyOnWriteArrayList 来提升性能。希望帮助读者选择合适的数据结构,写出更高效的代码。
40 3
|
14天前
|
存储 算法 Java
Java Set深度解析:为何它能成为“无重复”的代名词?
Java Set深度解析:为何它能成为“无重复”的代名词?本文详解Set接口及其主要实现类(HashSet、TreeSet、LinkedHashSet)的“无重复”特性,探讨其内部数据结构和算法实现,并通过示例代码展示最佳实践。
25 3
|
14天前
|
Java 开发者
在Java集合世界中,Set以其独特的特性脱颖而出,专门应对重复元素
在Java集合世界中,Set以其独特的特性脱颖而出,专门应对重复元素。通过哈希表和红黑树两种模式,Set能够高效地识别并拒绝重复元素的入侵,确保集合的纯净。无论是HashSet还是TreeSet,都能在不同的场景下发挥出色的表现,成为开发者手中的利器。
24 2
|
14天前
|
Java
Java Set以其“不重复”的特性,为我们提供了一个高效、简洁的处理唯一性约束数据的方式。
【10月更文挑战第16天】在Java编程中,Set接口确保集合中没有重复元素,每个元素都是独一无二的。HashSet基于哈希表实现,提供高效的添加、删除和查找操作;TreeSet则基于红黑树实现,不仅去重还能自动排序。通过这两个实现类,我们可以轻松处理需要唯一性约束的数据,提升代码质量和效率。
28 2
|
4天前
|
Java API Apache
java集合的组内平均值怎么计算
通过本文的介绍,我们了解了在Java中计算集合的组内平均值的几种方法。每种方法都有其优缺点,具体选择哪种方法应根据实际需求和场景决定。无论是使用传统的循环方法,还是利用Java 8的Stream API,亦或是使用第三方库(如Apache Commons Collections和Guava),都可以有效地计算集合的组内平均值。希望本文对您理解和实现Java中的集合平均值计算有所帮助。
11 0