SchemaNameCollection.ICollection.IsSynchronized Propriété

Définition

Obtient une valeur indiquant si l’accès à ICollection est synchronisé (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

Valeur de propriété

Boolean

true si l'accès à ICollection est synchronisé (thread-safe) ; sinon false.

Implémente

Remarques

SyncRoot retourne un objet qui peut être utilisé pour synchroniser l'accès à ICollection.

La plupart des classes de collection de l’espace System.Collections de noms implémentent également une méthode synchronisée, qui fournit un wrapper synchronisé autour de la collection sous-jacente.

L'énumération d'une collection n'est intrinsèquement pas une procédure thread-safe. Même lorsqu'une collection est synchronisée, les autres threads peuvent toujours la modifier, ce qui entraîne la levée d'une exception par l'énumérateur. Pour garantir la sécurité des threads au cours de l’énumération, vous pouvez verrouiller la collection pendant l’ensemble de l’énumération ou bien intercepter les exceptions résultant des modifications apportées par les autres threads.

L’exemple suivant montre comment verrouiller la collection à l’aide de l’énumération SyncRoot entière :

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  

S’applique à

Voir aussi