PropertyCollection.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é

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 Synchronized, qui fournit un wrapper synchronisé autour de la collection sous-jacente.

L’énumération par le biais d’une collection n’est pas intrinsèquement 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 pendant l’énumération, vous pouvez verrouiller la collection pendant toute l’énumération ou intercepter les exceptions qui résultent des modifications apportées par d’autres threads.

L’exemple suivant montre comment verrouiller la collection à l’aide de pendant SyncRoot toute l’énumération :

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