Dictionary<TKey,TValue>.ValueCollection.ICollection.SyncRoot Propriedade
Importante
Algumas informações se referem a produtos de pré-lançamento que podem ser substancialmente modificados antes do lançamento. A Microsoft não oferece garantias, expressas ou implícitas, das informações aqui fornecidas.
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
Um objeto que pode ser usado para sincronizar o acesso à ICollection. Na implementação padrão da Dictionary<TKey,TValue>.ValueCollection, essa propriedade sempre retorna a instância atual.
As implementações padrão de coleções em 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.
SyncRoot retorna um objeto , que pode ser usado para sincronizar o ICollectionacesso ao . A sincronização só será eficaz se todos os threads bloquearem esse 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 recuperação do valor dessa propriedade é uma operação O(1).
Comentários do .NET
O .NET é um projeto código aberto. Selecione um link para fornecer comentários: