Teilen über


Queue.SyncRoot Eigenschaft

Definition

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

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

Eigenschaftswert

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

Implementiert

Beispiele

Das folgende Codebeispiel zeigt, wie Sie die Auflistung mit der SyncRoot während der gesamten Enumeration sperren. Das Abrufen des Werts dieser Eigenschaft ist ein O(1) Vorgang.

Queue^ myCollection = gcnew Queue();
bool lockTaken = false;
try
{
    Monitor::Enter(myCollection->SyncRoot, lockTaken);
    for each (Object^ item in myCollection);
    {
        // Insert your code here.
    }
}
finally
{
    if (lockTaken)
    {
        Monitor::Exit(myCollection->SyncRoot);
    }
}
Queue myCollection = new Queue();
lock (myCollection.SyncRoot)
{
    foreach (object item in myCollection)
    {
        // Insert your code here.
    }
}
Dim myCollection As New Queue()
SyncLock myCollection.SyncRoot
    For Each item In myCollection
        ' Insert your code here.
    Next item
End SyncLock

Hinweise

Verwenden Sie die QueueSynchronized -Methode, um eine synchronisierte Version von zu erstellen. Abgeleitete Klassen können jedoch mithilfe der -Eigenschaft eine eigene synchronisierte Version von QueueSyncRoot bereitstellen. Der Synchronisierungscode muss Vorgänge für den SyncRoot von Queueausführen, nicht direkt für Queue. Dies gewährleistet die einwandfreie Funktion von Auflistungen, die von anderen Objekten abgeleitet sind. Insbesondere behält sie eine ordnungsgemäße Synchronisierung mit anderen Threads bei, die Queue 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:

Weitere Informationen