BitArray.SyncRoot Egenskap

Definition

Hämtar ett objekt som kan användas för att synkronisera åtkomsten BitArraytill .

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

Egenskapsvärde

Ett objekt som kan användas för att synkronisera åtkomsten BitArraytill .

Implementeringar

Exempel

I följande kodexempel visas hur du låser samlingen med hjälp av SyncRoot under hela uppräkningen.

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

Att hämta värdet för den här egenskapen är en O(1) åtgärd.

Kommentarer

Härledda klasser kan tillhandahålla en egen synkroniserad version av egenskapen med hjälp SyncRoot av BitArray egenskapen . Synkroniseringskoden måste utföra åtgärder på SyncRoot , BitArrayinte direkt på BitArray. Detta säkerställer korrekt drift av samlingar som härleds från andra objekt. Mer specifikt upprätthåller den korrekt synkronisering med andra trådar som kan ändra BitArray objektet samtidigt.

Att räkna upp genom en samling är i sig inte en trådsäker procedur. Även när en samling synkroniseras kan andra trådar fortfarande ändra samlingen, vilket gör att uppräknaren genererar ett undantag. För att garantera trådsäkerheten under uppräkningen kan du antingen låsa samlingen under hela uppräkningen eller fånga undantagen från ändringar som gjorts av andra trådar.

Gäller för

Se även