Array.SyncRoot Propriedade

Definição

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

public:
 property System::Object ^ SyncRoot { System::Object ^ get(); };
public:
 virtual property System::Object ^ SyncRoot { System::Object ^ get(); };
public object SyncRoot { get; }
public virtual object SyncRoot { get; }
member this.SyncRoot : obj
Public ReadOnly Property SyncRoot As Object
Public Overridable ReadOnly Property SyncRoot As Object

Valor de Propriedade

Um objeto que pode ser usado para sincronizar o acesso ao Array.

Implementações

Exemplos

O seguinte exemplo de código mostra como bloquear um array durante toda a enumeração usando a SyncRoot propriedade.

Array myArray = new int[] { 1, 2, 4 };
lock(myArray.SyncRoot)
{
    foreach (Object item in myArray)
        Console.WriteLine(item);
}
let myArray = [| 1; 2; 4|]
lock myArray.SyncRoot (fun () ->
    for item in myArray do
        printfn $"{item}" )
Dim myArray As Array = New Integer() { 1, 2, 4 }
SyncLock(myArray.SyncRoot) 
    For Each item As Object In myArray
        Console.WriteLine(item)
    Next
End SyncLock

Observações

Esta propriedade implementa a System.Collections.ICollection interface.

.NET classes baseadas em Array fornecem a sua própria versão sincronizada da coleção usando a propriedade SyncRoot.

Classes que usam arrays também podem implementar a sua própria sincronização usando esta SyncRoot propriedade. O código de sincronização deve realizar operações sobre o SyncRoot da coleção, não diretamente sobre a coleção. Isto assegura o funcionamento adequado das coleções derivadas de outros objetos. Especificamente, mantém a sincronização adequada com outros threads que possam estar a modificar simultaneamente a coleção. Note que algumas implementações de SyncRoot podem devolver o Array próprio .

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.

Recuperar o valor desta propriedade é uma operação O(1).

Aplica-se a

Ver também