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

Método ArrayList.Synchronized (IList)

 

Publicado: octubre de 2016

Devuelve un contenedor de la clase IList que está sincronizado (es seguro para subprocesos).

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

[HostProtectionAttribute(SecurityAction.LinkDemand, Synchronization = true)]
public static IList Synchronized(
	IList list
)

Parámetros

list
Type: System.Collections.IList

IList que se va a sincronizar.

Valor devuelto

Type: System.Collections.IList

Contenedor de la clase IList que está sincronizado (es seguro para subprocesos).

Exception Condition
ArgumentNullException

El valor de list es null.

Para garantizar la seguridad para subprocesos de la ArrayList, todas las operaciones deben realizarse a través de este contenedor.

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.

En el ejemplo de código siguiente se muestra cómo bloquear la colección utilizando el SyncRoot durante toda la enumeración.

ArrayList myCollection = new ArrayList();

lock(myCollection.SyncRoot)
{
    foreach (object item in myCollection)
    {
        // Insert your code here.
    }
}

Este método es una operación o (1).

Plataforma universal de Windows
Disponible desde 10
.NET Framework
Disponible desde 1.1
Volver al principio
Mostrar: