Condividi tramite


PropertyCollection.ICollection.IsSynchronized Proprietà

Definizione

Ottiene un valore che indica se l'accesso a ICollection è 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 a ICollection è sincronizzato (thread-safe); in caso contrario, false.

Implementazioni

Commenti

SyncRoot restituisce un oggetto che può essere utilizzato per sincronizzare l'accesso a ICollection.

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 se una raccolta è sincronizzata, è possibile che venga modificata da altri thread, con conseguente 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 durante SyncRoot 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