Dictionary<TKey,TValue>.ICollection.SyncRoot Eigenschaft
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.
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.
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.
Die SyncRoot -Eigenschaft gibt ein -Objekt zurück, das zum Synchronisieren des Zugriffs auf den ICollectionverwendet werden kann. Die Synchronisierung ist nur wirksam, wenn alle Threads das 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);
}
Der Wert dieser Eigenschaft wird durch einen O(1)-Vorgang abgerufen.