Freigeben über


DTSReadOnlyCollectionBase.SyncRoot Eigenschaft

Definition

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

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

Eigenschaftswert

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

Implementiert

Beispiele

Im folgenden Codebeispiel wird gezeigt, wie Sie eine ArrayList Auflistung mithilfe SyncRoot der Aufzählung sperren.

using System;  
using System.Collections;  

ArrayList myCollection = new ArrayList();  
lock( myCollection.SyncRoot )   
foreach ( Object item in myCollection )   
{  
    // Insert your code here.  
}  
Imports System  
Imports System.Collections  

Dim myCollection As ArrayList =  New ArrayList()   

lock(myCollection.SyncRoot)  
For Each item In myCollection  
    ' Insert your code here.  
Next  

Hinweise

Implementiert ICollection.IsSynchronized. Wenn Sie eine benutzerdefinierte Auflistung erstellen und von DTSReadOnlyCollectionBaseihnen abgeleitet werden, können Sie ihre eigene synchronisierte Version der Auflistung mithilfe der SyncRoot Eigenschaft bereitstellen. Der Synchronisierungscode muss Vorgänge auf der SyncRoot Auflistung ausführen, nicht direkt auf der Auflistung. Dies gewährleistet die einwandfreie Funktion von Auflistungen, die von anderen Objekten abgeleitet sind. Insbesondere verwaltet es die richtige Synchronisierung mit anderen Threads, die gleichzeitig das Objekt ändern.

Die Enumeration einer Auflistung ist systemintern keine threadsichere Prozedur. Selbst wenn eine Auflistung synchronisiert wird, könnte andere Threads die Auflistung weiterhin ändern, wodurch der Aufzählungsator eine Ausnahme ausgelöst wird. 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. Weitere Informationen finden Sie unter ICollection.IsSynchronized.

Gilt für: