Auf Englisch lesen

Teilen über


ArrayList.SyncRoot Eigenschaft

Definition

Ruft ein Objekt ab, mit dem der Zugriff auf ArrayList synchronisiert werden kann.

C#
public virtual object SyncRoot { get; }

Eigenschaftswert

Ein Objekt, mit dem der Zugriff auf ArrayList synchronisiert werden kann.

Implementiert

Beispiele

Im folgenden Codebeispiel wird gezeigt, wie die Auflistung während der gesamten Enumeration mit gesperrt SyncRoot wird.

C#
ArrayList myCollection = new ArrayList();

lock(myCollection.SyncRoot)
{
    foreach (object item in myCollection)
    {
        // Insert your code here.
    }
}

Das Abrufen des Werts dieser Eigenschaft ist ein O(1) Vorgang.

Hinweise

Verwenden Sie die ArrayListSynchronized -Methode, um eine synchronisierte Version von zu erstellen. Abgeleitete Klassen können jedoch mithilfe der SyncRoot -Eigenschaft eine eigene synchronisierte Version von ArrayList bereitstellen. Der Synchronisierungscode muss Vorgänge für den SyncRoot von ArrayListausführen, nicht direkt für .ArrayList Dies gewährleistet die einwandfreie Funktion von Auflistungen, die von anderen Objekten abgeleitet sind. Insbesondere wird eine ordnungsgemäße Synchronisierung mit anderen Threads beibehalten, die ArrayList das Objekt möglicherweise gleichzeitig ändern.

Die Enumeration einer Auflistung ist systemintern keine threadsichere Prozedur. Selbst wenn eine Auflistung synchronisiert wird, besteht die Möglichkeit, dass andere Threads sie ändern. Dies führt dazu, dass der Enumerator eine Ausnahme auslöst. Um während der Enumeration Threadsicherheit zu gewährleisten, können Sie entweder die Auflistung während der gesamten Enumeration sperren oder die Ausnahmen, die aus von anderen Threads stammenden Änderungen resultieren, abfangen.

Gilt für:

Produkt Versionen
.NET Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Framework 1.1, 2.0, 3.0, 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
.NET Standard 2.0, 2.1
UWP 10.0

Weitere Informationen