Sdílet prostřednictvím


SqlParameterCollection.IsSynchronized Vlastnost

Definice

Získá hodnotu, která označuje, zda SqlParameterCollection je synchronizován.

public:
 virtual property bool IsSynchronized { bool get(); };
public override bool IsSynchronized { get; }
member this.IsSynchronized : bool
Public Overrides ReadOnly Property IsSynchronized As Boolean

Hodnota vlastnosti

true SqlParameterCollection pokud je synchronizován; falsev opačném případě .

Poznámky

Tento člen je explicitní implementace člena rozhraní. Lze jej použít pouze v případě, SqlParameterCollection že je instance přetypována do ICollection rozhraní.

SyncRoot vrátí objekt, který lze použít k synchronizaci přístupu k objektu ICollection. Většina tříd kolekcí v System.Collections oboru názvů také implementuje synchronizovanou metodu, která poskytuje synchronizovaný obálku kolem podkladové kolekce.

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.

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

ICollection^ myCollection = someCollection;
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);
    }
}
ICollection myCollection = someCollection;
lock(myCollection.SyncRoot)
{
    foreach (object item in myCollection)
    {
        // Insert your code here.
    }
}
Dim myCollection As ICollection = someCollection
SyncLock myCollection.SyncRoot
    For Each item In myCollection
        ' Insert your code here.
    Next item
End SyncLock

Platí pro

Viz také