Leer en inglés

Compartir a través de


Array.IsSynchronized Propiedad

Definición

Obtiene un valor que indica si el acceso a la interfaz Array está sincronizado (es seguro para subprocesos).

C#
public bool IsSynchronized { get; }
C#
public virtual bool IsSynchronized { get; }

Valor de propiedad

Esta propiedad es siempre false para todas las matrices.

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

Array implementa la IsSynchronized propiedad porque es necesaria para 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

Consulte también