HashSet Klasse
Definition
Wichtig
Einige Informationen beziehen sich auf Vorabversionen, die vor dem Release ggf. grundlegend überarbeitet werden. Microsoft übernimmt hinsichtlich der hier bereitgestellten Informationen keine Gewährleistungen, seien sie ausdrücklich oder konkludent.
Diese Klasse implementiert die Set
Schnittstelle, unterstützt durch eine Hashtabelle (tatsächlich eine HashMap
Instanz).
[Android.Runtime.Register("java/util/HashSet", DoNotGenerateAcw=true)]
[Java.Interop.JavaTypeParameters(new System.String[] { "E" })]
public class HashSet : Java.Util.AbstractSet, IDisposable, Java.Interop.IJavaPeerable, Java.IO.ISerializable, Java.Lang.ICloneable
[<Android.Runtime.Register("java/util/HashSet", DoNotGenerateAcw=true)>]
[<Java.Interop.JavaTypeParameters(new System.String[] { "E" })>]
type HashSet = class
inherit AbstractSet
interface ISerializable
interface IJavaObject
interface IDisposable
interface IJavaPeerable
interface ICloneable
interface ISet
interface ICollection
interface IIterable
- Vererbung
- Abgeleitet
- Attribute
- Implementiert
Hinweise
Diese Klasse implementiert die Set
Schnittstelle, unterstützt durch eine Hashtabelle (tatsächlich eine HashMap
Instanz). Es garantiert nicht die Iterationsreihenfolge des Satzes; Insbesondere garantiert sie nicht, dass die Bestellung im Laufe der Zeit konstant bleibt. Diese Klasse lässt das null
Element zu.
Diese Klasse bietet konstante Zeitleistung für die grundlegenden Vorgänge (add
, remove
contains
und size
), vorausgesetzt, die Hashfunktion verteilt die Elemente ordnungsgemäß zwischen den Buckets. Das Durchlaufen über diesen Satz erfordert Zeit proportional zur Summe der Größe der HashSet
Instanz (die Anzahl der Elemente) sowie die "Kapazität" der Sicherungsinstanz HashMap
(die Anzahl der Buckets). Daher ist es sehr wichtig, die anfängliche Kapazität nicht zu hoch (oder den Lastfaktor zu niedrig) festzulegen, wenn die Iterationsleistung wichtig ist.
<strong>Note that this implementation is not synchronized.</strong> Wenn mehrere Threads gleichzeitig auf einen Hashsatz zugreifen und mindestens einer der Threads den Satz ändert, muss er extern synchronisiert werden. Dies wird in der Regel durch Synchronisieren für ein Objekt erreicht, das den Satz natürlich kapselt.
Wenn kein solches Objekt vorhanden ist, sollte der Satz mithilfe der Collections#synchronizedSet Collections.synchronizedSet
Methode "wrapped" sein. Dies geschieht am besten zur Erstellungszeit, um versehentlichen nicht synchronisierten Zugriff auf die Gruppe zu verhindern:
Set s = Collections.synchronizedSet(new HashSet(...));
Die von der Methode dieser Klasse iterator
zurückgegebenen Iteratoren sind fail-fast: Wenn der Satz jederzeit geändert wird, nachdem der Iterator erstellt wurde, mit Ausnahme der eigenen remove
Methode des Iterators, löst der Iterator eine ConcurrentModificationException
. Daher schlägt der Iterator angesichts der gleichzeitigen Änderung schnell und sauber fehl, anstatt willkürliches, nicht deterministisches Verhalten zu einem unbestimmten Zeitpunkt in der Zukunft zu riskieren.
Beachten Sie, dass das fehlschnelle Verhalten eines Iterators nicht garantiert werden kann, da es im Allgemeinen unmöglich ist, im Vorhandensein einer nicht synchronisierten gleichzeitigen Änderung hart garantiert zu werden. Fail-fast iterators throw ConcurrentModificationException
on a best-effort. Daher wäre es falsch, ein Programm zu schreiben, das von dieser Ausnahme für seine Richtigkeit abhängig ist: Das fehlerschnelle Verhalten von Iteratoren sollte nur verwendet werden, um Fehler zu erkennen.
Diese Klasse ist ein Mitglied des Java Collections Framework.
In 1.2 hinzugefügt.
Java-Dokumentation für java.util.HashSet
.
Teile dieser Seite sind Änderungen auf der Grundlage von Arbeiten, die vom Android Open Source-Projekt erstellt und freigegeben werden und gemäß den in der Creative Commons 2.5 Attribution License beschriebenen Begriffen verwendet werden.
Konstruktoren
HashSet() |
Erstellt einen neuen, leeren Satz; Die Sicherungsinstanz |
HashSet(ICollection) |
Erstellt einen neuen Satz, der die Elemente in der angegebenen Auflistung enthält. |
HashSet(Int32) |
Erstellt einen neuen, leeren Satz; Die Sicherungsinstanz |
HashSet(Int32, Single) |
Erstellt einen neuen, leeren Satz; die Sicherungsinstanz |
HashSet(IntPtr, JniHandleOwnership) |
Ein Konstruktor, der beim Erstellen verwalteter Darstellungen von JNI-Objekten verwendet wird; wird von der Laufzeit aufgerufen. |
Eigenschaften
Class |
Gibt die Laufzeitklasse dieses Werts |
Handle |
Das Handle für die zugrunde liegende Android-Instanz. (Geerbt von Object) |
IsEmpty |
So wird's hinzugefügt (Geerbt von AbstractCollection) |
JniIdentityHashCode |
Diese Klasse implementiert die |
JniPeerMembers |
Diese Klasse implementiert die |
PeerReference |
Diese Klasse implementiert die |
ThresholdClass |
Diese API unterstützt die Mono für Android-Infrastruktur und ist nicht für die direkte Verwendung aus Ihrem Code vorgesehen. |
ThresholdType |
Diese API unterstützt die Mono für Android-Infrastruktur und ist nicht für die direkte Verwendung aus Ihrem Code vorgesehen. |
Methoden
Add(Object) |
So wird's hinzugefügt (Geerbt von AbstractCollection) |
AddAll(ICollection) |
So wird's hinzugefügt (Geerbt von AbstractCollection) |
Clear() |
So wird's hinzugefügt (Geerbt von AbstractCollection) |
Clone() |
Gibt eine flache Kopie dieser |
Contains(Object) |
So wird's hinzugefügt (Geerbt von AbstractCollection) |
ContainsAll(ICollection) |
So wird's hinzugefügt (Geerbt von AbstractCollection) |
Dispose() |
Diese Klasse implementiert die |
Dispose(Boolean) |
Diese Klasse implementiert die |
Equals(Object) |
Gibt an, ob ein anderes Objekt "gleich" diesem Objekt ist. (Geerbt von Object) |
GetHashCode() |
Gibt einen Hashcodewert für das Objekt zurück. (Geerbt von Object) |
Iterator() |
Gibt einen Iterator für die Elemente in diesem Satz zurück. |
JavaFinalize() |
Wird vom Garbage Collector für ein Objekt aufgerufen, wenn die Garbage Collection bestimmt, dass keine weiteren Verweise auf das Objekt vorhanden sind. (Geerbt von Object) |
Notify() |
Aktiviert einen einzelnen Thread, der auf dem Monitor dieses Objekts wartet. (Geerbt von Object) |
NotifyAll() |
Aktiviert alle Threads, die auf dem Monitor dieses Objekts warten. (Geerbt von Object) |
Remove(Object) |
So wird's hinzugefügt (Geerbt von AbstractCollection) |
RemoveAll(ICollection) |
So wird's hinzugefügt (Geerbt von AbstractCollection) |
RetainAll(ICollection) |
So wird's hinzugefügt (Geerbt von AbstractCollection) |
SetHandle(IntPtr, JniHandleOwnership) |
Legt die Handle-Eigenschaft fest. (Geerbt von Object) |
Size() |
Gibt die Anzahl der Elemente in diesem Satz (seine Kardinalität) zurück. |
Spliterator() |
Erstellt eine <em>late-binding</em und <em>fail-fast</em>> |
ToArray() |
So wird's hinzugefügt (Geerbt von AbstractCollection) |
ToArray(Object[]) |
So wird's hinzugefügt (Geerbt von AbstractCollection) |
ToArray<T>() |
Diese Klasse implementiert die |
ToString() |
Gibt eine Zeichenfolgendarstellung des Objekts zurück. (Geerbt von Object) |
UnregisterFromRuntime() |
Diese Klasse implementiert die |
Wait() |
Bewirkt, dass der aktuelle Thread wartet, bis er wach ist, in der Regel durch em benachrichtigt/em> oder <em>unterbrochen</em>.<>< (Geerbt von Object) |
Wait(Int64) |
Bewirkt, dass der aktuelle Thread wartet, bis er wach ist, in der Regel durch <em>benachrichtigt</em> oder <em>unterbrochen</em> oder bis eine bestimmte Menge an Echtzeit verstrichen ist. (Geerbt von Object) |
Wait(Int64, Int32) |
Bewirkt, dass der aktuelle Thread wartet, bis er wach ist, in der Regel durch <em>benachrichtigt</em> oder <em>unterbrochen</em> oder bis eine bestimmte Menge an Echtzeit verstrichen ist. (Geerbt von Object) |
Explizite Schnittstellenimplementierungen
IJavaPeerable.Disposed() |
Diese Klasse implementiert die |
IJavaPeerable.DisposeUnlessReferenced() |
Diese Klasse implementiert die |
IJavaPeerable.Finalized() |
Diese Klasse implementiert die |
IJavaPeerable.JniManagedPeerState |
Diese Klasse implementiert die |
IJavaPeerable.SetJniIdentityHashCode(Int32) |
Diese Klasse implementiert die |
IJavaPeerable.SetJniManagedPeerState(JniManagedPeerStates) |
Diese Klasse implementiert die |
IJavaPeerable.SetPeerReference(JniObjectReference) |
Diese Klasse implementiert die |
Erweiterungsmethoden
JavaCast<TResult>(IJavaObject) |
Führt eine android-laufzeitgecheckte Typkonvertierung aus. |
JavaCast<TResult>(IJavaObject) |
Diese Klasse implementiert die |
GetJniTypeName(IJavaPeerable) |
Diese Klasse implementiert die |
ToEnumerable(IIterable) |
Diese Klasse implementiert die |
ToEnumerable<T>(IIterable) |
Diese Klasse implementiert die |