SearchResultCollection.ICollection.IsSynchronized Propriedade

Definição

Recebe um valor que indica se o acesso ao ICollection é sincronizado (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

Valor de Propriedade

true se o acesso ao ICollection for sincronizado (thread safe); caso contrário, false.

Implementações

Observações

SyncRoot devolve um objeto, que pode ser usado para sincronizar o acesso ao ICollection.

A maioria das classes de coleção no System.Collections namespace também implementa um método Synchronized, que fornece um wrapper sincronizado em torno da coleção subjacente.

Enumerar através de uma coleção não é intrinsecamente um procedimento seguro para threads. Mesmo quando uma coleção está sincronizada, outros threads ainda podem modificar a coleção, o que faz com que o enumerador lance uma exceção. Para garantir a segurança dos threads durante a enumeração, pode bloquear a coleção durante toda a enumeração ou apanhar as exceções resultantes de alterações feitas por outros threads.

O seguinte exemplo de código mostra como bloquear a coleção usando o SyncRoot durante toda a enumeração:

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

Aplica-se a

Ver também