Este artículo se tradujo automáticamente. Para ver el artículo en inglés, active la casilla Inglés. Además, puede mostrar el texto en inglés en una ventana emergente si mueve el puntero del mouse sobre el texto.
Traducción
Inglés

Propiedad Array.SyncRoot

 

Publicado: octubre de 2016

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

Espacio de nombres:   System
Ensamblado:  mscorlib (en mscorlib.dll)

public object SyncRoot { get; }

Valor de propiedad

Type: System.Object

Objeto que se puede usar para sincronizar el acceso a Array.

Esta propiedad implementa la System.Collections.ICollection interfaz.

Clases de .NET framework se basan en Array proporcionar su propia versión sincronizada de la colección mediante el SyncRoot propiedad.

Las clases que utilizan matrices también pueden implementar su propia sincronización utilizando la SyncRoot propiedad. El código de sincronización debe realizar las operaciones en el SyncRoot de 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 correcta con otros subprocesos que podrían modificar al mismo tiempo la colección. Tenga en cuenta que algunas implementaciones de SyncRoot podría devolver el Array propio.

Enumerar 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).

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

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

.NET Framework
Disponible desde 1.1
Silverlight
Disponible desde 2.0
Windows Phone Silverlight
Disponible desde 7.0
Volver al principio
Mostrar: