Partilhar via


SortedDictionary<TKey,TValue>.ICollection.SyncRoot Propriedade

Definição

Obtém um objeto que pode ser usado para sincronizar o acesso ao ICollection.

property System::Object ^ System::Collections::ICollection::SyncRoot { System::Object ^ get(); };
object System.Collections.ICollection.SyncRoot { get; }
member this.System.Collections.ICollection.SyncRoot : obj
 ReadOnly Property SyncRoot As Object Implements ICollection.SyncRoot

Valor da propriedade

Um objeto que pode ser usado para sincronizar o acesso à ICollection.

Implementações

Comentários

As implementações padrão de coleções no namespace System.Collections.Generic não são sincronizadas.

A enumeração por meio de uma coleção não é um procedimento thread-safe intrínseco. Para garantir acesso thread-safe durante a enumeração, é possível bloquear a coleção durante toda a enumeração. Para permitir que a coleção seja acessada por vários threads para leitura e gravação, você deve implementar sua própria sincronização.

A ICollection.SyncRoot propriedade retorna um objeto que pode ser usado para sincronizar o ICollectionacesso ao . A sincronização só será efetiva se todos os threads bloquearem o objeto antes de acessar a coleção. O código a seguir mostra o uso da SyncRoot propriedade para C#, C++e Visual Basic.

ICollection ic = ...;  
lock (ic.SyncRoot)   
{  
    // Access the collection.  
}  
Dim ic As ICollection = ...  
SyncLock ic.SyncRoot  
    ' Access the collection.  
End SyncLock  
ICollection^ ic = ...;  
try   
{  
    Monitor::Enter(ic->SyncRoot);  
    // Access the collection.  
}  
finally   
{  
    Monitor::Exit(ic->SyncRoot);  
}  

A obtenção do valor dessa propriedade é uma operação O(1).

Aplica-se a

Confira também