Freigeben über


List<T>.ICollection.SyncRoot Eigenschaft

Definition

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

property System::Object ^ System::Collections::ICollection::SyncRoot { System::Object ^ get(); };
object System.Collections.ICollection.SyncRoot { get; }
member this.System.Collections.ICollection.SyncRoot : obj
 ReadOnly Property SyncRoot As Object Implements ICollection.SyncRoot

Eigenschaftswert

Ein Objekt, mit dem der Zugriff auf ICollection synchronisiert werden kann. In der Standardimplementierung der List<T> gibt diese Eigenschaft immer die aktuelle Instanz zurück.

Implementiert

Hinweise

Standardimplementierungen der Auflistungen im System.Collections.Generic-Namespace werden nicht synchronisiert.

Die Enumeration einer Auflistung ist systemintern keine threadsichere Prozedur. Um während der Enumeration Threadsicherheit zu garantieren, können Sie die Auflistung während der gesamten Enumeration sperren. Um den Lese- und Schreibzugriff auf diese Auflistung durch mehrere Threads zuzulassen, müssen Sie eine eigene Synchronisierung implementieren.

SyncRoot Gibt ein Objekt, das verwendet werden kann, zum Synchronisieren des Zugriffs auf die ICollection. Die Synchronisierung ist nur wirksam, wenn alle Threads dieses Objekt vor dem Zugriff auf die Auflistung sperren. Der folgende Code zeigt die Verwendung der SyncRoot -Eigenschaft für C#, C++ und Visual Basic.

ICollection ic = ...;
lock (ic.SyncRoot)
{
    // Access the collection.
}
Dim ic As ICollection = ...
SyncLock ic.SyncRoot
    ' Access the collection.
End SyncLock
ICollection^ ic = ...;
try
{
    Monitor::Enter(ic->SyncRoot);
    // Access the collection.
}
finally
{
    Monitor::Exit(ic->SyncRoot);
}

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

Gilt für:

Weitere Informationen