SyncRoot Propiedad
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

Hashtable.SyncRoot (Propiedad)

 

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

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

public virtual object SyncRoot { get; }

Valor de propiedad

Type: System.Object

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

Implementaciones

ICollection.SyncRoot

Para crear una versión sincronizada de la Hashtable, utilice el Synchronized método.Sin embargo, las clases derivadas pueden proporcionar su propia versión sincronizada de la Hashtable mediante el SyncRoot propiedad.El código de sincronización debe realizar operaciones en el SyncRoot de la Hashtable, no directamente en el Hashtable .Esto garantiza un funcionamiento correcto de las colecciones que se derivan de otros objetos.En concreto, mantiene la sincronización correcta con otros subprocesos que podrían modificar simultáneamente el Hashtable objeto.

Enumerar una colección no es un procedimiento seguro para subprocesos.Incluso cuando una colección está sincronizada, otros subprocesos pueden modificarla, lo que hace que el enumerador produzca una excepción.Para garantizar la seguridad para subprocesos durante la enumeración, 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:

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

Universal Windows Platform
Disponible desde 10
.NET Framework
Disponible desde 1.1
Volver al principio
Mostrar:
© 2016 Microsoft