SortedDictionary<TKey,TValue>.KeyCollection.Enumerator Estructura
Definición
Importante
Parte de la información hace referencia a la versión preliminar del producto, que puede haberse modificado sustancialmente antes de lanzar la versión definitiva. Microsoft no otorga ninguna garantía, explícita o implícita, con respecto a la información proporcionada aquí.
Enumera los elementos de un SortedDictionary<TKey,TValue>.KeyCollectionobjeto .
public: value class SortedDictionary<TKey, TValue>::KeyCollection::Enumerator : System::Collections::Generic::IEnumerator<TKey>
public struct SortedDictionary<TKey,TValue>.KeyCollection.Enumerator : System.Collections.Generic.IEnumerator<TKey>
type SortedDictionary<'Key, 'Value>.KeyCollection.Enumerator = struct
interface IEnumerator<'Key>
interface IEnumerator
interface IDisposable
type SortedDictionary<'Key, 'Value>.KeyCollection.Enumerator = struct
interface IEnumerator<'Key>
interface IDisposable
interface IEnumerator
Public Structure SortedDictionary(Of TKey, TValue).KeyCollection.Enumerator
Implements IEnumerator(Of TKey)
Parámetros de tipo
- TKey
- TValue
- Herencia
- Implementaciones
Comentarios
La foreach instrucción del lenguaje C# (For Each en Visual Basic) oculta la complejidad de los enumeradores. Por lo tanto, se recomienda usar foreach , en lugar de manipular directamente el enumerador.
Los enumeradores se pueden usar para leer los datos de la colección, pero no se pueden usar para modificar la colección subyacente.
Inicialmente, el enumerador se coloca antes del primer elemento de la colección. En esta posición, Current no está definido. 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 objeto hasta MoveNext que se llama a . MoveNext establece Current en el elemento siguiente.
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 a MoveNext también devuelven false. Si la última llamada a MoveNext se falsedevuelve , Current no está definida. No se puede establecer Current de nuevo en el primer elemento de la colección; debe crear una nueva instancia del enumerador en su lugar.
Un enumerador sigue siendo válido siempre que la colección permanezca sin cambios. 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 produce una InvalidOperationExceptionexcepción .
El enumerador no tiene acceso exclusivo a la colección; por lo tanto, la enumeración a través de una colección no es intrínsecamente un procedimiento seguro para subprocesos. Para garantizar la seguridad de los subprocesos durante la enumeración, puede bloquear la colección durante toda la enumeración. Para permitir que varios subprocesos puedan acceder a la colección para leer y escribir, debe implementar su propia sincronización.
Las implementaciones predeterminadas de colecciones en el System.Collections.Generic espacio de nombres no se sincronizan.
Propiedades
| Nombre | Description |
|---|---|
| Current |
Obtiene el elemento en la posición actual del enumerador. |
Métodos
| Nombre | Description |
|---|---|
| Dispose() |
Libera todos los recursos usados por .SortedDictionary<TKey,TValue>.KeyCollection.Enumerator |
| MoveNext() |
Desplaza el enumerador al siguiente elemento de .SortedDictionary<TKey,TValue>.KeyCollection |
Implementaciones de interfaz explícitas
| Nombre | Description |
|---|---|
| IEnumerator.Current |
Obtiene el elemento en la posición actual del enumerador. |
| IEnumerator.Reset() |
Establece el enumerador en su posición inicial, que es antes del primer elemento de la colección. |