Table of Contents
HashSet collection
LinkedHashSet collection:
TreeSet collection:
Home Java javaTutorial How to understand the set collection in Java

How to understand the set collection in Java

Jun 20, 2022 am 11:31 AM
java

This article brings you relevant knowledge about java, which mainly introduces related issues about set collections. The characteristics of set collections are disordered, non-repeating and without indexes. The following is Let's take a look, hope it helps everyone.

How to understand the set collection in Java

Recommended study: "java video tutorial"

Set series collection features:

  • Unordered: The access sequence is inconsistent
  • No duplication: Duplication can be removed
  • No index: There is no indexed method, so ordinary methods cannot be used For loop traversal, elements cannot be obtained by index

Set collection implementation class features:

HashSet:Unordered, no duplication, no index

LinkedHashSet:Ordered, no duplication, no index

TreeSet:Sort, no duplication , No index

The function of the Set collection is basically the same as the API of Collection.

HashSet collection

HashSet collection:

Set<String> set = new HashSet<>();
        set.add("石原里美");
        set.add("石原里美");
        set.add("工藤静香");
        set.add("朱茵");
        System.out.println(set);
        set.remove("朱茵");
        System.out.println(set);
Copy after login

Output result:

Through the above From the code and running results, we can clearly see that the HashSet collection is disordered and non-repeating;

Combined with the above pictures, we can see that the HashSet collection cannot Data is obtained through the index of the get() method, and when deleting data in the collection, the data can only be deleted in a targeted manner.

LinkedHashSet collection:

LinkedHashSet collection:

Set<String> set = new LinkedHashSet<>();
        set.add("石原里美");
        set.add("石原里美");
        set.add("工藤静香");
        set.add("朱茵");
        System.out.println(set);
        set.remove("朱茵");
        System.out.println(set);
Copy after login

Output result:

Passed Comparing the above code with the output results, you can see the difference between disordered and ordered. The former will disrupt the order of the incoming data, while the latter will still store the data in the order of the input data, so the output Time is in order.

TreeSet collection:

TreeSet collection:

Set<Integer> set = new TreeSet<>();
        set.add(13);
        set.add(23);
        set.add(23);
        set.add(11);
        System.out.println(set);
        set.remove(23);
        System.out.println(set);
Copy after login

Output result:

Passed From the above code and output results, we can understand literally why TreeSet is characterized by sorting, that is, the stored data is sorted according to Java's default sorting method.

However, if you store custom objects such as People at this time, TreeSet cannot be sorted directly, and an error will occur!

//People类:
public class People{
    private String name;
    private int age;
    private String classroom;

    public People(){

    }
    public People(String name, int age, String classroom) {
        this.name = name;
        this.age = age;
        this.classroom = classroom;
    }

    public String getName() {
        return name;
    }

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

    public int getAge() {
        return age;
    }

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

    public String getClassroom() {
        return classroom;
    }

    public void setClassroom(String classroom) {
        this.classroom = classroom;
    }

    @Override
    public String toString() {
        return "People{" +
                "name='" + name + '\'' +
                ", age=" + age +
                ", classroom='" + classroom + '\'' +
                '}';
    }
}
//main方法:
public static void main(String[] args) {
        Set<People> p = new TreeSet<>();
        p.add(new People("张三",19,"智能"));
        p.add(new People("李四",18,"数据库"));
        p.add(new People("王五",20,"渗透"));
        System.out.println(p);
    }
Copy after login

If we want to solve this problem, we need to customize the storage type for the TreeSet collection. There are two ways to solve this problem: One is to customize the class to implement the Comparable interface and Rewrite the compareTo method inside to specify the rules; The other is a collection with its own comparator object for rule definition.

Method 1: Custom class implements the Comparable interface and rewrites the compareTo method to specify the comparison rules (the redundant and irrelevant code will not be repeated here, only the important part of the code will be shown) )

//改变的第一个地方:实现Comparable类
public class People implements Comparable<People> {
//改变的第二个地方:重写Comparable类中的compareTo方法    
    @Override
    public int compareTo(People o) {
        return this.age-o.age;
    }
}
Copy after login

Output result (compared according to age):

In the overridden method, the code after return determines what the object will be based on The comparison rules are as follows:

  • If the first element is considered to be greater than the second element, a positive integer can be returned
  • If the first element is considered to be less than the second element Just return a negative integer
  • If you think the first element is equal to the second element, just return 0. At this time, the Treeset collection will only retain one element, and both are considered duplicates

Method 2:The collection comes with a comparator object for rule definition

Set<People> p = new TreeSet<>(new Comparator<People>() {
            @Override
            public int compare(People o1, People o2) {
                return o1.getAge()-o2.getAge();
            }
        });
Copy after login

Change the creation of the collection on the original basis, and its comparison criteria are similar to the previous definition method, relatively The previous method is more convenient and faster. Here, we can also review some of the previously learned knowledge "Lambda expressions" and simplify the code block.

Set<People> p = new TreeSet<>((o1, o2) -> o1.getAge()-o2.getAge());
Copy after login

If you have not studied Lambda expressions, or your knowledge of Lambda expressions is not clear, you can look at how to understand lambda expressions in Java - simplifying the explanation of this article may help Something helpful to you.

Recommended learning: "java video tutorial"

The above is the detailed content of How to understand the set collection in Java. For more information, please follow other related articles on the PHP Chinese website!

Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

Video Face Swap

Video Face Swap

Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

Break or return from Java 8 stream forEach? Break or return from Java 8 stream forEach? Feb 07, 2025 pm 12:09 PM

Java 8 introduces the Stream API, providing a powerful and expressive way to process data collections. However, a common question when using Stream is: How to break or return from a forEach operation? Traditional loops allow for early interruption or return, but Stream's forEach method does not directly support this method. This article will explain the reasons and explore alternative methods for implementing premature termination in Stream processing systems. Further reading: Java Stream API improvements Understand Stream forEach The forEach method is a terminal operation that performs one operation on each element in the Stream. Its design intention is

PHP: A Key Language for Web Development PHP: A Key Language for Web Development Apr 13, 2025 am 12:08 AM

PHP is a scripting language widely used on the server side, especially suitable for web development. 1.PHP can embed HTML, process HTTP requests and responses, and supports a variety of databases. 2.PHP is used to generate dynamic web content, process form data, access databases, etc., with strong community support and open source resources. 3. PHP is an interpreted language, and the execution process includes lexical analysis, grammatical analysis, compilation and execution. 4.PHP can be combined with MySQL for advanced applications such as user registration systems. 5. When debugging PHP, you can use functions such as error_reporting() and var_dump(). 6. Optimize PHP code to use caching mechanisms, optimize database queries and use built-in functions. 7

PHP vs. Python: Understanding the Differences PHP vs. Python: Understanding the Differences Apr 11, 2025 am 12:15 AM

PHP and Python each have their own advantages, and the choice should be based on project requirements. 1.PHP is suitable for web development, with simple syntax and high execution efficiency. 2. Python is suitable for data science and machine learning, with concise syntax and rich libraries.

PHP vs. Other Languages: A Comparison PHP vs. Other Languages: A Comparison Apr 13, 2025 am 12:19 AM

PHP is suitable for web development, especially in rapid development and processing dynamic content, but is not good at data science and enterprise-level applications. Compared with Python, PHP has more advantages in web development, but is not as good as Python in the field of data science; compared with Java, PHP performs worse in enterprise-level applications, but is more flexible in web development; compared with JavaScript, PHP is more concise in back-end development, but is not as good as JavaScript in front-end development.

PHP vs. Python: Core Features and Functionality PHP vs. Python: Core Features and Functionality Apr 13, 2025 am 12:16 AM

PHP and Python each have their own advantages and are suitable for different scenarios. 1.PHP is suitable for web development and provides built-in web servers and rich function libraries. 2. Python is suitable for data science and machine learning, with concise syntax and a powerful standard library. When choosing, it should be decided based on project requirements.

Java Program to Find the Volume of Capsule Java Program to Find the Volume of Capsule Feb 07, 2025 am 11:37 AM

Capsules are three-dimensional geometric figures, composed of a cylinder and a hemisphere at both ends. The volume of the capsule can be calculated by adding the volume of the cylinder and the volume of the hemisphere at both ends. This tutorial will discuss how to calculate the volume of a given capsule in Java using different methods. Capsule volume formula The formula for capsule volume is as follows: Capsule volume = Cylindrical volume Volume Two hemisphere volume in, r: The radius of the hemisphere. h: The height of the cylinder (excluding the hemisphere). Example 1 enter Radius = 5 units Height = 10 units Output Volume = 1570.8 cubic units explain Calculate volume using formula: Volume = π × r2 × h (4

PHP: The Foundation of Many Websites PHP: The Foundation of Many Websites Apr 13, 2025 am 12:07 AM

The reasons why PHP is the preferred technology stack for many websites include its ease of use, strong community support, and widespread use. 1) Easy to learn and use, suitable for beginners. 2) Have a huge developer community and rich resources. 3) Widely used in WordPress, Drupal and other platforms. 4) Integrate tightly with web servers to simplify development deployment.

Create the Future: Java Programming for Absolute Beginners Create the Future: Java Programming for Absolute Beginners Oct 13, 2024 pm 01:32 PM

Java is a popular programming language that can be learned by both beginners and experienced developers. This tutorial starts with basic concepts and progresses through advanced topics. After installing the Java Development Kit, you can practice programming by creating a simple "Hello, World!" program. After you understand the code, use the command prompt to compile and run the program, and "Hello, World!" will be output on the console. Learning Java starts your programming journey, and as your mastery deepens, you can create more complex applications.

See all articles