SortedDictionary<TKey,TValue>.Enumerator SortedDictionary<TKey,TValue>.Enumerator SortedDictionary<TKey,TValue>.Enumerator SortedDictionary<TKey,TValue>.Enumerator Struct

Definizione

Enumera gli elementi di un oggetto SortedDictionary<TKey,TValue>.Enumerates the elements of a SortedDictionary<TKey,TValue>.

public: value class SortedDictionary<TKey, TValue>::Enumerator : System::Collections::Generic::IEnumerator<System::Collections::Generic::KeyValuePair<TKey, TValue>>, System::Collections::IDictionaryEnumerator
public struct SortedDictionary<TKey,TValue>.Enumerator : System.Collections.Generic.IEnumerator<System.Collections.Generic.KeyValuePair<TKey,TValue>>, System.Collections.IDictionaryEnumerator
type SortedDictionary<'Key, 'Value>.Enumerator = struct
    interface IEnumerator<KeyValuePair<'Key, 'Value>>
    interface IDictionaryEnumerator
    interface IDisposable
    interface IEnumerator
Public Structure SortedDictionary(Of TKey, TValue).Enumerator
Implements IDictionaryEnumerator, IEnumerator(Of KeyValuePair(Of TKey, TValue))

Parametri di tipo

TKey
TValue
Ereditarietà
SortedDictionary<TKey,TValue>.EnumeratorSortedDictionary<TKey,TValue>.EnumeratorSortedDictionary<TKey,TValue>.EnumeratorSortedDictionary<TKey,TValue>.Enumerator
Implementazioni

Commenti

Il foreach istruzione del linguaggio c# (for each in C++, For Each in Visual Basic) nasconde la complessità degli enumeratori.The foreach statement of the C# language (for each in C++, For Each in Visual Basic) hides the complexity of enumerators. Pertanto, si consiglia l'utilizzo di foreach, anziché la modifica diretta dell'enumeratore.Therefore, using foreach is recommended, instead of directly manipulating the enumerator.

È possibile utilizzare enumeratori per leggere i dati nella raccolta, ma non per modificare la raccolta sottostante.Enumerators can be used to read the data in the collection, but they cannot be used to modify the underlying collection.

Inizialmente l'enumeratore è posizionato davanti al primo elemento della raccolta.Initially, the enumerator is positioned before the first element in the collection. In questa posizione, la proprietà Current è indefinita.At this position, Current is undefined. È necessario chiamare il MoveNext per passare l'enumeratore al primo elemento della raccolta prima di leggere il valore del metodo Current.You must call the MoveNext method to advance the enumerator to the first element of the collection before reading the value of Current.

Il Current lo stesso oggetto finché non viene restituita la MoveNext viene chiamato.The Current property returns the same object until MoveNext is called. MoveNext imposta Current sull'elemento successivo.MoveNext sets Current to the next element.

Se MoveNext raggiunge la fine della raccolta, l'enumeratore è posizionato dopo l'ultimo elemento nella raccolta e MoveNext restituisce false.If MoveNext passes the end of the collection, the enumerator is positioned after the last element in the collection and MoveNext returns false. Quando l'enumeratore si trova in questa posizione, le chiamate successive a MoveNext restituire anche false.When the enumerator is at this position, subsequent calls to MoveNext also return false. Se l'ultima chiamata a MoveNext restituite false, Current è definito.If the last call to MoveNext returned false, Current is undefined. Non è possibile impostare nuovamente la proprietà Current sul primo elemento della raccolta; è necessario creare una nuova istanza di enumeratore.You cannot set Current to the first element of the collection again; you must create a new enumerator instance instead.

Un enumeratore rimane valido fino a quando la raccolta non subisce modifiche.An enumerator remains valid as long as the collection remains unchanged. Se vengono apportate modifiche alla raccolta, ad esempio l'aggiunta, modifica, o l'eliminazione di elementi, l'enumeratore viene invalidato in modo irreversibile e alla successiva chiamata a MoveNext oppure IEnumerator.Reset genera un InvalidOperationException.If changes are made to the collection, such as adding, modifying, or deleting elements, the enumerator is irrecoverably invalidated and the next call to MoveNext or IEnumerator.Reset throws an InvalidOperationException.

L'enumeratore non dispone di accesso esclusivo alla raccolta. L'enumerazione di una raccolta non è quindi una procedura thread-safe.The enumerator does not have exclusive access to the collection; therefore, enumerating through a collection is intrinsically not a thread-safe procedure. Per assicurare la protezione del thread durante l'enumerazione, è possibile bloccare la raccolta durante l'intera enumerazione.To guarantee thread safety during enumeration, you can lock the collection during the entire enumeration. Per consentire l'accesso alla raccolta in lettura e scrittura da parte di più thread, è necessario implementare la propria sincronizzazione.To allow the collection to be accessed by multiple threads for reading and writing, you must implement your own synchronization.

Le implementazioni predefinite di raccolte nello spazio dei nomi System.Collections.Generic non sono sincronizzate.Default implementations of collections in the System.Collections.Generic namespace are not synchronized.

Proprietà

Current Current Current Current

Ottiene l'elemento in corrispondenza della posizione corrente dell'enumeratore.Gets the element at the current position of the enumerator.

Metodi

Dispose() Dispose() Dispose() Dispose()

Rilascia tutte le risorse usate da SortedDictionary<TKey,TValue>.Enumerator.Releases all resources used by the SortedDictionary<TKey,TValue>.Enumerator.

MoveNext() MoveNext() MoveNext() MoveNext()

Sposta l'enumeratore all'elemento successivo dell'oggetto SortedDictionary<TKey,TValue>.Advances the enumerator to the next element of the SortedDictionary<TKey,TValue>.

Implementazioni dell'interfaccia esplicita

IDictionaryEnumerator.Entry IDictionaryEnumerator.Entry IDictionaryEnumerator.Entry IDictionaryEnumerator.Entry

Ottiene l'elemento in corrispondenza della posizione corrente dell'enumeratore come una struttura DictionaryEntry.Gets the element at the current position of the enumerator as a DictionaryEntry structure.

IDictionaryEnumerator.Key IDictionaryEnumerator.Key IDictionaryEnumerator.Key IDictionaryEnumerator.Key

Ottiene la chiave dell'elemento nella posizione corrente dell'enumeratore.Gets the key of the element at the current position of the enumerator.

IDictionaryEnumerator.Value IDictionaryEnumerator.Value IDictionaryEnumerator.Value IDictionaryEnumerator.Value

Ottiene il valore dell'elemento nella posizione corrente dell'enumeratore.Gets the value of the element at the current position of the enumerator.

IEnumerator.Current IEnumerator.Current IEnumerator.Current IEnumerator.Current

Ottiene l'elemento in corrispondenza della posizione corrente dell'enumeratore.Gets the element at the current position of the enumerator.

IEnumerator.Reset() IEnumerator.Reset() IEnumerator.Reset() IEnumerator.Reset()

Imposta l'enumeratore sulla propria posizione iniziale, ovvero prima del primo elemento nella raccolta.Sets the enumerator to its initial position, which is before the first element in the collection.

Si applica a

Vedi anche