Leggere in inglese

Condividi tramite


Array.SyncRoot Proprietà

Definizione

Ottiene un oggetto che può essere usato per sincronizzare l'accesso a Array.

C#
public object SyncRoot { get; }
C#
public virtual object SyncRoot { get; }

Valore della proprietà

Oggetto che può essere utilizzato per sincronizzare l'accesso a Array.

Implementazioni

Esempio

Nell'esempio di codice seguente viene illustrato come bloccare una matrice durante l'intera enumerazione usando la SyncRoot proprietà .

C#
Array myArray = new int[] { 1, 2, 4 };
lock(myArray.SyncRoot)
{
    foreach (Object item in myArray)
        Console.WriteLine(item);
}

Commenti

Questa proprietà implementa l'interfaccia System.Collections.ICollection .

Le classi .NET basate su Array forniscono la propria versione sincronizzata della raccolta usando la SyncRoot proprietà .

Le classi che usano matrici possono anche implementare la propria sincronizzazione usando la SyncRoot proprietà . Il codice di sincronizzazione deve eseguire operazioni sull'oggetto SyncRoot della raccolta, non direttamente nella raccolta. In questo modo si garantisce il corretto funzionamento delle raccolte derivate da altri oggetti. In particolare, mantiene una corretta sincronizzazione con altri thread che potrebbero modificare contemporaneamente la raccolta. Si noti che alcune implementazioni di SyncRoot potrebbero restituire l'oggetto Array stesso.

L'enumerazione tramite una raccolta non è intrinsecamente una procedura thread-safe. Anche se una raccolta è sincronizzata, è possibile che venga modificata da altri thread, con conseguente generazione di un'eccezione da parte dell'enumeratore. Per garantire la protezione dei thread durante l'enumerazione, è possibile bloccare la raccolta per l'intera enumerazione oppure intercettare le eccezioni determinate dalle modifiche apportate da altri thread.

Il recupero del valore di questa proprietà è un'operazione O(1).

Si applica a

Prodotto Versioni
.NET Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9, 10
.NET Framework 1.1, 2.0, 3.0, 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
.NET Standard 2.0, 2.1

Vedi anche