SearchResultCollection.ICollection.IsSynchronized Propriété

Définition

Obtient une valeur indiquant si l’accès au 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 au thread est synchronisé (thread safe) ; sinon, false.

Implémente

Remarques

SyncRoot retourne un objet, qui peut être utilisé pour synchroniser l’accès ICollectionau .

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

L’énumération par le biais d’une collection n’est intrinsèquement pas une procédure sécurisée de thread. Même lorsqu’une collection est synchronisée, d’autres threads peuvent toujours modifier la collection, ce qui provoque 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 résultant des modifications apportées par d’autres threads.

L’exemple de code 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