Array.IsSynchronized Propriedade

Definição

Recebe um valor que indica se o acesso ao Array é sincronizado (thread safe).

public:
 property bool IsSynchronized { bool get(); };
public:
 virtual property bool IsSynchronized { bool get(); };
public bool IsSynchronized { get; }
public virtual bool IsSynchronized { get; }
member this.IsSynchronized : bool
Public ReadOnly Property IsSynchronized As Boolean
Public Overridable ReadOnly Property IsSynchronized As Boolean

Valor de Propriedade

Esta propriedade aplica-se sempre false a todos os arrays.

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

Array implementa a IsSynchronized propriedade porque é exigida pela 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