CollectionBase.ICollection.IsSynchronized CollectionBase.ICollection.IsSynchronized CollectionBase.ICollection.IsSynchronized Property

Definizione

Ottiene un valore che indica se l'accesso a CollectionBase è sincronizzato (thread-safe).Gets a value indicating whether access to the CollectionBase is synchronized (thread safe).

property bool System::Collections::ICollection::IsSynchronized { bool get(); };
bool System.Collections.ICollection.IsSynchronized { get; }
 ReadOnly Property IsSynchronized As Boolean Implements ICollection.IsSynchronized

Valore della proprietà

true se l'accesso a CollectionBase è sincronizzato (thread-safe); in caso contrario, false.true if access to the CollectionBase is synchronized (thread safe); otherwise, false. Il valore predefinito è false.The default is false.

Implementazioni

Commenti

Un' CollectionBase istanza non è sincronizzata.A CollectionBase instance is not synchronized. Le classi derivate possono fornire una versione CollectionBase sincronizzata SyncRoot di utilizzando la proprietà.Derived classes can provide a synchronized version of the CollectionBase using the SyncRoot property.

L'enumerazione di una raccolta non è intrinsecamente una procedura thread-safe.Enumerating through a collection is intrinsically not a thread safe procedure. Anche se una raccolta è sincronizzata, è possibile che venga modificata da altri thread, con conseguente generazione di un'eccezione da parte dell'enumeratore.Even when a collection is synchronized, other threads can still modify the collection, which causes the enumerator to throw an exception. Per garantire la protezione dei thread durante l'enumerazione, è possibile bloccare la raccolta per l'intera enumerazione oppure intercettare le eccezioni determinate dalle modifiche apportate da altri thread.To guarantee thread safety during enumeration, you can either lock the collection during the entire enumeration or catch the exceptions resulting from changes made by other threads.

Nell'esempio di codice seguente viene illustrato come bloccare la raccolta utilizzando SyncRoot l'oggetto durante l'intera enumerazione:The following code example shows how to lock the collection using the SyncRoot during the entire enumeration:

// Get the ICollection interface from the CollectionBase
// derived class.
ICollection^ myCollection = myCollectionBase;
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);
    }
}
// Get the ICollection interface from the CollectionBase
// derived class.
ICollection myCollection = myCollectionBase;
lock(myCollection.SyncRoot)
{
    foreach (object item in myCollection)
    {
        // Insert your code here.
    }
}
' Get the ICollection interface from the CollectionBase
' derived class.
Dim myCollection As ICollection = myCollectionBase
SyncLock myCollection.SyncRoot
    For Each item As Object In myCollection
        ' Insert your code here.
    Next item
End SyncLock

Il recupero del valore di questa proprietà è un'operazione O(1).Retrieving the value of this property is an O(1) operation.

Si applica a

Vedi anche