Partager via


Stack.SyncRoot Propriété

Définition

Obtient un objet qui peut être utilisé pour synchroniser l’accès Stackau .

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

Valeur de propriété

Qui Object peut être utilisé pour synchroniser l’accès au Stack.

Implémente

Remarques

Pour créer une version synchronisée du Stack, utilisez la Synchronized méthode. Toutefois, les classes dérivées peuvent fournir leur propre version synchronisée de l’utilisation Stack de la SyncRoot propriété. Le code synchronisant doit effectuer des opérations sur le SyncRootStack, pas directement sur le Stack. Cela garantit le bon fonctionnement des collections dérivées d’autres objets. Plus précisément, il gère une synchronisation appropriée avec d’autres threads qui peuvent modifier simultanément l’objet Stack .

L’énumération par le biais d’une collection n’est intrinsèquement pas une procédure thread-safe. Même lorsqu’une collection est synchronisée, d’autres threads peuvent toujours modifier la collection, ce qui provoque la levée d’une exception par l’énumérateur. Pour garantir la sécurité des threads pendant l’énumération, vous pouvez verrouiller la collection pendant toute l’énumération ou intercepter les exceptions résultant des modifications apportées par d’autres threads.

L’exemple de code suivant montre comment verrouiller la collection à l’aide de l’énumération SyncRoot entière.

Stack myCollection = new Stack();

lock (myCollection.SyncRoot)
{
    foreach (object item in myCollection)
    {
        // Insert your code here.
    }
}
Dim myCollection As New Stack()

SyncLock myCollection.SyncRoot
    For Each item As Object In myCollection
        ' Insert your code here.
    Next item
End SyncLock

La récupération de la valeur de cette propriété est une O(1) opération.

S’applique à