Partager via


BitArray.SyncRoot Propriété

Définition

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

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

Valeur de propriété

Objet qui peut être utilisé pour synchroniser l’accès au BitArray.

Implémente

Exemples

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

BitArray myCollection = new BitArray(64, true);
lock(myCollection.SyncRoot)
{
    foreach (object item in myCollection)
    {
        // Insert your code here.
    }
}
Dim myCollection As New BitArray(64, true)
SyncLock myCollection.SyncRoot
    For Each item 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.

Remarques

Les classes dérivées peuvent fournir leur propre version synchronisée de l’utilisation BitArray de la SyncRoot propriété. Le code synchronisant doit effectuer des opérations sur le SyncRootBitArray, pas directement sur le BitArray. 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 BitArray .

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.

S’applique à

Voir aussi