Share via


ForEachItems.SyncRoot Eigenschaft

Definition

Ruft ein Objekt ab, mit dem der Zugriff auf die ForEachItems-Auflistung 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 die ForEachItems-Auflistung synchronisiert werden kann.

Implementiert

Beispiele

Im folgenden Codebeispiel wird gezeigt, wie Sie eine ArrayList Auflistung während SyncRoot der Enumeration 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 DTSReadOnlyCollectionBasediesem abgeleitet werden, können Sie ihre eigene synchronisierte Version der Auflistung mithilfe der SyncRoot Eigenschaft bereitstellen. Der Synchronisierungscode muss Vorgänge für die SyncRoot Auflistung ausführen, nicht direkt in der Auflistung. Dies gewährleistet die einwandfreie Funktion von Auflistungen, die von anderen Objekten abgeleitet sind. Insbesondere wird die ordnungsgemäße Synchronisierung mit anderen Threads beibehalten, die das Objekt möglicherweise gleichzeitig ändern.

Die Enumeration einer Auflistung ist systemintern keine threadsichere Prozedur. Auch wenn eine Auflistung synchronisiert wird, könnten andere Threads die Auflistung weiterhin ändern, was dazu führt, dass der Aufzählungsator 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. Weitere Informationen finden Sie unter ICollection.IsSynchronized.

Gilt für: