PropertyCollection.ICollection.IsSynchronized Proprietà

Definizione

Ottiene un valore che indica se l'accesso ICollection a è sincronizzato (thread-safe).

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

Valore della proprietà

true se l'accesso ICollection a è sincronizzato (thread-safe); in caso contrario, false.

Implementazioni

Commenti

SyncRoot restituisce un oggetto , che può essere utilizzato per sincronizzare l'accesso ICollectiona .

La maggior parte delle classi di raccolta nello System.Collections spazio dei nomi implementa anche un metodo Synchronized, che fornisce un wrapper sincronizzato intorno alla raccolta sottostante.

L'enumerazione tramite una raccolta non è intrinsecamente una procedura thread-safe. Anche quando una raccolta viene sincronizzata, altri thread possono comunque modificare la raccolta, causando la generazione di un'eccezione da parte dell'enumeratore. Per garantire la thread safety durante l'enumerazione, è possibile bloccare la raccolta durante l'intera enumerazione o intercettare le eccezioni risultanti dalle modifiche apportate da altri thread.

Nell'esempio seguente viene illustrato come bloccare la raccolta usando SyncRoot durante l'intera enumerazione:

ICollection myCollection = new ICollection();
  lock(myCollection.SyncRoot) {
  foreach (Object item in myCollection) {
  // Insert your code here.
  }
 }
Dim myCollection As New ICollection()
 Dim item As Object
 SyncLock myCollection.SyncRoot
  For Each item In myCollection
  ' Insert your code here.
  Next item
 End SyncLock

Si applica a

Vedi anche