Sdílet prostřednictvím


BitArray.SyncRoot Vlastnost

Definice

Získá objekt, který lze použít k synchronizaci přístupu k BitArray.

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

Hodnota vlastnosti

Objekt, který lze použít k synchronizaci přístupu k objektu BitArray.

Implementuje

Příklady

Následující příklad kódu ukazuje, jak uzamknout kolekci pomocí celého výčtu SyncRoot .

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

Načtení hodnoty této vlastnosti je O(1) operace.

Poznámky

Odvozené třídy mohou poskytovat vlastní synchronizovanou verzi BitArray použití SyncRoot vlastnosti. Synchronizační kód musí provádět operace s SyncRootBitArray, nikoli přímo na straně BitArray. Tím se zajistí správná operace kolekcí odvozených z jiných objektů. Konkrétně udržuje správnou synchronizaci s jinými vlákny, která mohou současně upravovat BitArray objekt.

Výčet prostřednictvím kolekce není vnitřně bezpečným postupem pro přístup z více vláken. I když je kolekce synchronizována, ostatní vlákna mohou stále upravovat kolekci, což způsobí, že enumerátor vyvolá výjimku. Chcete-li zaručit bezpečnost vláken během výčtu, můžete buď uzamknout kolekci během celého výčtu, nebo zachytit výjimky vyplývající z změn provedených jinými vlákny.

Platí pro

Viz také