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 DictionaryBase.ICollection.SyncRoot

 

Publicado: octubre de 2016

Obtiene un objeto que se puede utilizar para sincronizar el acceso a un objeto DictionaryBase.

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

object ICollection.SyncRoot { get; }

Valor de propiedad

Type: System.Object

Objeto que puede utilizarse para sincronizar el acceso al objeto DictionaryBase.

Las clases derivadas pueden proporcionar su propia versión sincronizada de la DictionaryBase clase utilizando el SyncRoot propiedad. El código de sincronización debe realizar operaciones en el SyncRoot propiedad de la DictionaryBase objeto, no directamente en la DictionaryBase objeto. 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 simultáneamente el DictionaryBase objeto.

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 la SyncRoot propiedad durante toda la enumeración.

ICollection myCollection = new ShortStringDictionary();
lock(myCollection.SyncRoot)
{
    foreach (Object item in myCollection)
    {
        // Insert your code here.
    }
}

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

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