List<T>.Enumerator Estrutura

Definição

Enumera os elementos de um List<T>.

public: value class List<T>::Enumerator : System::Collections::Generic::IEnumerator<T>
public struct List<T>.Enumerator : System.Collections.Generic.IEnumerator<T>
[System.Serializable]
public struct List<T>.Enumerator : System.Collections.Generic.IEnumerator<T>
type List<'T>.Enumerator = struct
    interface IEnumerator<'T>
    interface IEnumerator
    interface IDisposable
[<System.Serializable>]
type List<'T>.Enumerator = struct
    interface IEnumerator<'T>
    interface IDisposable
    interface IEnumerator
Public Structure List(Of T).Enumerator
Implements IEnumerator(Of T)

Parâmetros de Tipo Genérico

T
Herança
List<T>.Enumerator
Atributos
Implementações

Observações

A afirmação foreach da linguagem C# (For Each em Visual Basic) esconde a complexidade dos enumeradores. Por isso, recomenda-se o uso foreach , em vez de manipular diretamente o enumerador.

Os enumeradores podem ser usados para ler os dados da 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 é indefinido. Portanto, deve chamar MoveNext para avançar o enumerador até ao primeiro elemento da coleção antes de ler o valor de Current.

Current devolve o mesmo objeto até MoveNext ser chamado. MoveNext passa Current para o elemento seguinte.

Se MoveNext passar o final da coleção, o enumerador é posicionado após o último elemento da coleção e MoveNext retorna false. Quando o enumerador está nesta posição, chamadas subsequentes também MoveNext retornam false. Se a última chamada devolvida MoveNextfalse, Current for indefinida. Não pode voltar a definir Current para o primeiro elemento da coleção; deve criar uma nova instância de enumerador em vez disso.

Um enumerador mantém-se válido enquanto a coleção permanecer inalterada. Se forem feitas alterações à coleção, como adicionar, modificar ou eliminar elementos, o enumerador fica irremediavelmente invalidado e a próxima chamada para MoveNext ou IEnumerator.Reset lança um InvalidOperationException.

O enumerador não tem acesso exclusivo à coleção; Portanto, enumerar através de uma coleção não é intrinsecamente um procedimento seguro para threads. Para garantir a segurança da linha durante a enumeração, pode bloquear a coleção durante toda a enumeração. Para permitir que a coleção seja acedida por múltiplos threads para leitura e escrita, deve implementar a sua própria sincronização.

As implementações padrão das coleções em System.Collections.Generic não estão sincronizadas.

Propriedades

Name Description
Current

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

Métodos

Name Description
Dispose()

Liberta todos os recursos utilizados pelo List<T>.Enumerator.

MoveNext()

Avança o enumerador para o próximo elemento do List<T>.

Implementações de Interface Explícita

Name Description
IEnumerator.Current

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

IEnumerator.Reset()

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

Aplica-se a

Ver também