Llegeix en anglès

Comparteix a través de


Array.SyncRoot Propiedad

Definición

Obtiene un objeto que se puede usar para sincronizar el acceso a Array.

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

Valor de propiedad

Un objeto que se puede usar para sincronizar el acceso a la clase Array.

Implementaciones

Ejemplos

En el ejemplo de código siguiente se muestra cómo bloquear una matriz durante toda la enumeración mediante la SyncRoot propiedad .

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

Comentarios

Esta propiedad implementa la System.Collections.ICollection interfaz .

Las clases de .NET basadas en Array proporcionan su propia versión sincronizada de la colección mediante la SyncRoot propiedad .

Las clases que usan matrices también pueden implementar su propia sincronización mediante la SyncRoot propiedad . El código de sincronización debe realizar operaciones en de SyncRoot la colección, no directamente en la colección. De este modo, se garantiza el funcionamiento correcto de las colecciones derivadas de otros objetos. En concreto, mantiene la sincronización adecuada con otros subprocesos que podrían modificar simultáneamente la colección. Tenga en cuenta que algunas implementaciones de SyncRoot pueden devolver el Array propio .

La enumeración a través de una colección no es intrínsecamente un procedimiento seguro para subprocesos. Incluso cuando una colección está sincronizada, otros subprocesos todavía pueden modificarla, lo que hace que el enumerador produzca una excepción. Con el fin de garantizar la seguridad para la ejecución de subprocesos durante la enumeración, se puede bloquear la colección durante toda la enumeración o detectar las excepciones resultantes de los cambios realizados por otros subprocesos.

La recuperación del valor de esta propiedad es una operación O(1).

Se aplica a

Producte Versions
.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

Consulte también