NameObjectCollectionBase.ICollection.IsSynchronized Propriedade
Definição
Importante
Algumas informações dizem respeito a um produto pré-lançado que pode ser substancialmente modificado antes de ser lançado. A Microsoft não faz garantias, de forma expressa ou implícita, em relação à informação aqui apresentada.
Recebe um valor que indica se o acesso ao NameObjectCollectionBase objeto está 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 NameObjectCollectionBase objeto for sincronizado (thread safe); caso contrário, false. A predefinição é false.
Implementações
Observações
Um NameObjectCollectionBase objeto não está sincronizado. As classes derivadas podem fornecer uma versão sincronizada do NameObjectCollectionBase usando a SyncRoot propriedade.
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 exemplo de código seguinte mostra como bloquear a coleção usando a SyncRoot propriedade durante toda a enumeração.
// Create a collection derived from NameObjectCollectionBase
ICollection myCollection = new DerivedCollection();
lock(myCollection.SyncRoot)
{
foreach (object item in myCollection)
{
// Insert your code here.
}
}
' Create a collection derived from NameObjectCollectionBase
Dim myCollection As ICollection = New DerivedCollection()
SyncLock myCollection.SyncRoot
For Each item As Object In myCollection
' Insert your code here.
Next item
End SyncLock
Recuperar o valor desta propriedade é uma operação O(1).