SortedDictionary<TKey,TValue>.GetEnumerator Método

Definición

Devuelve un enumerador que recorre en iteración la colección SortedDictionary<TKey,TValue>.

public:
 System::Collections::Generic::SortedDictionary<TKey, TValue>::Enumerator GetEnumerator();
public System.Collections.Generic.SortedDictionary<TKey,TValue>.Enumerator GetEnumerator ();
member this.GetEnumerator : unit -> System.Collections.Generic.SortedDictionary<'Key, 'Value>.Enumerator
Public Function GetEnumerator () As SortedDictionary(Of TKey, TValue).Enumerator

Devoluciones

Estructura SortedDictionary<TKey,TValue>.Enumerator para la colección SortedDictionary<TKey,TValue>.

Comentarios

Para fines de enumeración, cada elemento es una KeyValuePair<TKey,TValue> estructura que representa un valor y su clave.

La foreach instrucción del lenguaje C# (for each en C++, For Each en Visual Basic) oculta la complejidad de los enumeradores. Por lo tanto, se recomienda el uso de foreach, en lugar de manipular directamente el enumerador.

Los enumeradores pueden usarse para leer los datos de la colección, pero no para modificar la colección subyacente.

El diccionario se mantiene en un orden ordenado mediante un árbol interno. Cada nuevo elemento se coloca en la posición de ordenación correcta y el árbol se ajusta para mantener el criterio de ordenación cada vez que se quita un elemento. Al enumerar, se mantiene el criterio de ordenación.

En principio, el enumerador se coloca antes del primer elemento de la colección. En esta posición, la Current propiedad no está definida. Por lo tanto, debe llamar al MoveNext método para avanzar el enumerador al primer elemento de la colección antes de leer el valor de Current.

La Current propiedad devuelve el mismo elemento hasta que se llama al MoveNext método . MoveNext establece Current en el siguiente elemento.

Si MoveNext pasa el final de la colección, el enumerador se coloca después del último elemento de la colección y MoveNext devuelve false. Cuando el enumerador está en esta posición, las llamadas posteriores también devuelven MoveNextfalse. Si la última llamada a MoveNext se falsedevuelve , Current no está definida. No puede volver a establecer la propiedad Current en el primer elemento de la colección, sino que debe crear una nueva instancia del enumerador.

Un enumerador sigue siendo válido mientras la colección permanezca inalterada. Si se realizan cambios en la colección, como agregar, modificar o eliminar elementos, el enumerador se invalida irrecuperablemente y la siguiente llamada a MoveNext o IEnumerator.Reset inicia una InvalidOperationExceptionexcepción .

El enumerador no tiene acceso exclusivo a la colección y, por tanto, la enumeración en una colección no es intrínsicamente un procedimiento seguro para subprocesos. A fin de garantizar la seguridad de los subprocesos, se puede bloquear la colección durante toda la enumeración. Para permitir que varios subprocesos obtengan acceso de lectura y escritura a la colección, debe implementar su propia sincronización.

Las implementaciones predeterminadas de las colecciones del espacio de nombres System.Collections.Generic no están sincronizadas.

Este método es una operación O(log n), donde n es count.

Se aplica a

Consulte también