SortedDictionary<TKey,TValue>.KeyCollection.Enumerator Estrutura

Definição

Enumera os elementos de uma SortedDictionary<TKey,TValue>.KeyCollection.

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
Herança
SortedDictionary<TKey,TValue>.KeyCollection.Enumerator
Implementações

Comentários

A instrução foreach da linguagem C# (for each em C++, For Each no Visual Basic) oculta a complexidade de enumeradores. Portanto, o uso de foreach é recomendado, em vez de manipular diretamente o enumerador.

Os enumeradores podem ser usados para ler os dados na coleção, mas não podem ser usados para modificar a coleção subjacente.

Inicialmente, o enumerador é posicionado antes do primeiro elemento da coleção. Nesta posição, Current está indefinido. Você deve chamar o MoveNext método para avançar o enumerador para o primeiro elemento da coleção antes de ler o valor de Current.

A Current propriedade retorna o mesmo objeto até MoveNext ser chamada. MoveNext define Current como o próximo elemento.

Caso MoveNext passe o final da coleção, o enumerador é posicionado após o último elemento na coleção e MoveNext retorna false. Quando o enumerador está nessa posição, as chamadas subsequentes para MoveNext também retornam false. Caso a última chamada para MoveNext tenha retornado false, Current está indefinido. Não é possível definir Current como o primeiro elemento da coleção novamente; você deve criar uma nova instância de enumerador em vez disso.

Um enumerador permanece válido desde que a coleção permaneça inalterada. Se forem feitas alterações na coleção, como adicionar, modificar ou excluir elementos, o enumerador será invalidado irrecuperavelmente e a próxima chamada para MoveNext ou IEnumerator.Reset gerará um InvalidOperationException.

O enumerador não tem acesso exclusivo à coleção; por isso, a enumeração por meio de uma coleção não é um procedimento thread-safe intrínseco. Para garantir acesso thread-safe durante a enumeração, é possível bloquear a coleção durante toda a enumeração. Para permitir que a coleção seja acessada por vários threads para leitura e gravação, você deve implementar sua própria sincronização.

As implementações padrão de coleções no namespace System.Collections.Generic não são sincronizadas.

Propriedades

Current

Obtém o elemento na posição atual do enumerador.

Métodos

Dispose()

Libera todos os recursos usados pelo SortedDictionary<TKey,TValue>.KeyCollection.Enumerator.

MoveNext()

Avança o enumerador para o próximo elemento do SortedDictionary<TKey,TValue>.KeyCollection.

Implantações explícitas de interface

IEnumerator.Current

Obtém o elemento na posição atual do enumerador.

IEnumerator.Reset()

Define o enumerador com sua posição inicial, que é antes do primeiro elemento da coleção.

Aplica-se a

Confira também