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.
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:
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);</string>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);</string>Ausgabeergebnis:
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);</integer>Ausgabeergebnis:
//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);
}</people>
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; } }</people>
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(); } });</people></people>
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!

In dem Artikel werden Maven und Gradle für Java -Projektmanagement, Aufbau von Automatisierung und Abhängigkeitslösung erörtert, die ihre Ansätze und Optimierungsstrategien vergleichen.

In dem Artikel werden benutzerdefinierte Java -Bibliotheken (JAR -Dateien) mit ordnungsgemäßem Versioning- und Abhängigkeitsmanagement erstellt und verwendet, wobei Tools wie Maven und Gradle verwendet werden.

In dem Artikel wird in der Implementierung von mehrstufigem Caching in Java mithilfe von Koffein- und Guava-Cache zur Verbesserung der Anwendungsleistung erläutert. Es deckt die Einrichtungs-, Integrations- und Leistungsvorteile sowie die Bestrafung des Konfigurations- und Räumungsrichtlinienmanagements ab

In dem Artikel werden mit JPA für Objektrelationszuordnungen mit erweiterten Funktionen wie Caching und faulen Laden erläutert. Es deckt Setup, Entity -Mapping und Best Practices zur Optimierung der Leistung ab und hebt potenzielle Fallstricke hervor. [159 Charaktere]

Mit der Klassenbelastung von Java wird das Laden, Verknüpfen und Initialisieren von Klassen mithilfe eines hierarchischen Systems mit Bootstrap-, Erweiterungs- und Anwendungsklassenloadern umfasst. Das übergeordnete Delegationsmodell stellt sicher


Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

AI Hentai Generator
Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

Heiße Werkzeuge

ZendStudio 13.5.1 Mac
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver Mac
Visuelle Webentwicklungstools

SecLists
SecLists ist der ultimative Begleiter für Sicherheitstester. Dabei handelt es sich um eine Sammlung verschiedener Arten von Listen, die häufig bei Sicherheitsbewertungen verwendet werden, an einem Ort. SecLists trägt dazu bei, Sicherheitstests effizienter und produktiver zu gestalten, indem es bequem alle Listen bereitstellt, die ein Sicherheitstester benötigen könnte. Zu den Listentypen gehören Benutzernamen, Passwörter, URLs, Fuzzing-Payloads, Muster für vertrauliche Daten, Web-Shells und mehr. Der Tester kann dieses Repository einfach auf einen neuen Testcomputer übertragen und hat dann Zugriff auf alle Arten von Listen, die er benötigt.

VSCode Windows 64-Bit-Download
Ein kostenloser und leistungsstarker IDE-Editor von Microsoft

Dreamweaver CS6
Visuelle Webentwicklungstools