Heim  >  Artikel  >  Java  >  So verstehen Sie die Set-Sammlung in Java

So verstehen Sie die Set-Sammlung in Java

WBOY
WBOYnach vorne
2022-06-20 11:31:051794Durchsuche

Dieser Artikel bringt Ihnen relevantes Wissen über Java, das hauptsächlich verwandte Themen zu Mengensammlungen vorstellt. Die Eigenschaften von Mengensammlungen sind ungeordnet, nicht wiederholbar und ohne Indizes für dich. Jeder ist hilfreich.

So verstehen Sie die Set-Sammlung in Java

RECIMMILIERTE LERNUNG: "java Video Tutorial"

Set Collection Funktionen:

  • NORDEDED: Die Zugriffssequenz ist inkonsistent. ist keine indizierte Methode, daher können Sie keine gewöhnliche For-Schleifendurchquerung verwenden und auch keine Elemente über Indizes erhalten. Funktionen der Set-Collection-Implementierungsklasse:
  • HashSet:
Ungeordnet, nicht wiederholend, kein Index

LinkedHashSet: Ordnet, nicht dupliziert, kein Index

TreeSet: Sortieren, nicht dupliziert, kein Index

Die Funktion der Set-Sammlung ist grundsätzlich dieselbe wie die API der Sammlung.

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);
Ausgabeergebnis:

Über den oben genannten Code und laufende Ergebnisse können wir deutlich sehen, dass die Hashset-Sammlung nicht ordnungsgemäß und nicht wiederholt wird In Kombination mit dem obigen Bild ist ersichtlich, dass die HashSet-Sammlung keine Daten über den Index der get()-Methode abrufen kann und beim Löschen der Daten in der Sammlung die Daten nur durch gerichtetes Löschen gelöscht werden können. LinkedHashSet-Satz:

LinkedHashSet-Satz:

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

Durch Vergleich des obigen Codes mit dem Ausgabeergebnis können Sie den Unterschied zwischen Unordnung und Ordnung erkennen Eingehende Daten werden gestört, letzterer speichert die Daten jedoch weiterhin in der Reihenfolge der Eingabedaten, sodass die Ausgabe in einem geordneten Zustand ist.

TreeSet-Sammlung:

TreeSet-Sammlung:

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);
Ausgabeergebnis:

Durch den obigen Code und die Ausgabeergebnisse können wir buchstäblich verstehen, warum TreeSet durch Sortieren gekennzeichnet ist und die zu speichernden Daten entsprechend sind um nach der Standardsortiermethode von Java zu sortieren.

Wenn Sie jedoch zu diesem Zeitpunkt benutzerdefinierte Objekte wie Personenobjekte speichern, kann TreeSet nicht direkt sortiert werden und es tritt ein Fehler auf!

//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);
    }

Wenn wir dieses Problem lösen möchten, müssen wir den Speichertyp für die TreeSet-Sammlung anpassen. Es gibt zwei Möglichkeiten, dieses Problem zu lösen:

Eine besteht darin, die Klasse anzupassen, um die Comparable-Schnittstelle zu implementieren und die CompareTo-Methode zu überschreiben um die Regeln anzugeben ;Das andere

ist eine Sammlung mit einem eigenen Komparatorobjekt zur Regeldefinition.

Methode 1: Die benutzerdefinierte Klasse implementiert die Comparable-Schnittstelle und schreibt die CompareTo-Methode neu, um die Vergleichsregeln anzugeben (der redundante und irrelevante Code wird hier nicht beschrieben, nur der wichtige Teil des Codes wird angezeigt).

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

Ergebnisse ausgeben (gemäß Altersvergleich):

Bei der überschriebenen Methode bestimmt der Code nach der Rückgabe, nach welchen Kriterien das Objekt verglichen wird. Die Vergleichsregeln lauten wie folgt: Wenn das erste Element berücksichtigt wird größer als das zweite Element Geben Sie einfach eine positive Ganzzahl zurück

Wenn Sie denken, dass das erste Element kleiner als das zweite Element ist, geben Sie einfach eine negative Ganzzahl zurückWenn Sie denken, dass das erste Element gleich dem zweiten Element ist, geben Sie einfach 0 zurück Dieses Mal behält die Treeset-Sammlung nur ein Element bei. Es wird davon ausgegangen, dass es sich bei den beiden um Duplikate handelt Basierend auf dem Original festgelegt, und seine Vergleichskriterien ähneln relativ der vorherigen Definitionsmethode. Die vorherige Methode ist bequemer und schneller. Hier können wir auch einige der zuvor erlernten Kenntnisse über „Lambda-Ausdrücke“ überprüfen und den Codeblock vereinfachen.

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

Wenn Sie Lambda-Ausdrücke noch nicht studiert haben oder Ihre Kenntnisse über Lambda-Ausdrücke nicht klar sind, können Sie lesen, wie man Lambda-Ausdrücke in Java versteht – die vereinfachte Erklärung dieses Artikels kann Ihnen hilfreich sein.

Empfohlenes Lernen: „Java-Video-Tutorial

Das obige ist der detaillierte Inhalt vonSo verstehen Sie die Set-Sammlung in Java. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Dieser Artikel ist reproduziert unter:csdn.net. Bei Verstößen wenden Sie sich bitte an admin@php.cn löschen