Dictionary<TKey,TValue>.KeyCollection.Enumerator Struktura
Definice
Důležité
Některé informace platí pro předběžně vydaný produkt, který se může zásadně změnit, než ho výrobce nebo autor vydá. Microsoft neposkytuje žádné záruky, výslovné ani předpokládané, týkající se zde uváděných informací.
Vytvoří výčet prvků objektu Dictionary<TKey,TValue>.KeyCollection.
public: value class Dictionary<TKey, TValue>::KeyCollection::Enumerator : System::Collections::Generic::IEnumerator<TKey>
public struct Dictionary<TKey,TValue>.KeyCollection.Enumerator : System.Collections.Generic.IEnumerator<TKey>
[System.Serializable]
public struct Dictionary<TKey,TValue>.KeyCollection.Enumerator : System.Collections.Generic.IEnumerator<TKey>
type Dictionary<'Key, 'Value>.KeyCollection.Enumerator = struct
interface IEnumerator<'Key>
interface IEnumerator
interface IDisposable
[<System.Serializable>]
type Dictionary<'Key, 'Value>.KeyCollection.Enumerator = struct
interface IEnumerator<'Key>
interface IDisposable
interface IEnumerator
Public Structure Dictionary(Of TKey, TValue).KeyCollection.Enumerator
Implements IEnumerator(Of TKey)
Parametry typu
- TKey
- TValue
- Dědičnost
- Atributy
- Implementuje
Poznámky
Příkaz foreach
jazyka C# (for each
v jazyce C++, For Each
v jazyce Visual Basic) skrývá složitost enumerátorů. Proto se doporučuje použít foreach
místo přímé manipulace s enumerátorem.
Enumerátory lze používat ke čtení dat v kolekci, nikoli však k úpravě zdrojové kolekce.
Zpočátku je enumerátor umístěn před prvním prvkem v kolekci. Na této pozici Current není definován. Před čtením hodnoty Currentje nutné volat MoveNext pro přechod enumerátoru na první prvek kolekce.
Current vrátí stejný objekt, dokud MoveNext není volána. MoveNext nastaví Current na další prvek.
Pokud MoveNext projde konec kolekce, enumerátor se umístí za poslední prvek v kolekci a MoveNext vrátí false
. Když je enumerátor na této pozici, následné volání také MoveNext vrátí false
. Pokud je poslední volání MoveNext vráceno false
, Current není definováno. Nelze znovu nastavit Current na první prvek kolekce; místo toho musíte vytvořit novou instanci enumeratoru.
Enumerátor zůstane platný, dokud kolekce zůstane beze změny. Pokud jsou provedeny změny kolekce, například přidání prvků nebo změna kapacity, je výčet nenávratně zneplatněný a další volání MoveNext nebo IEnumerator.Reset vyvolá InvalidOperationException.
Pouze .NET Core 3.0+: Jediné metody mutace, které neaktivují výčty, jsou Remove a Clear.
Enumerátor nemá výhradní přístup ke kolekci; proto výčet prostřednictvím kolekce není vnitřně procedurou bezpečnou pro přístup z více vláken. Chcete-li zajistit bezpečnost vláken během výčtu, můžete uzamknout kolekci během celého výčtu. Chcete-li více vláknům umožnit přístup ke kolekci pro čtení a zápis, musíte implementovat svou vlastní synchronizaci.
Výchozí implementace kolekcí v nástroji System.Collections.Generic se nesynchronují.
Vlastnosti
Current |
Získá prvek na aktuální pozici enumerátoru. |
Metody
Dispose() |
Uvolní všechny prostředky používané nástrojem Dictionary<TKey,TValue>.KeyCollection.Enumerator. |
MoveNext() |
Posune enumerátor na další prvek objektu Dictionary<TKey,TValue>.KeyCollection. |
Explicitní implementace rozhraní
IEnumerator.Current |
Získá prvek na aktuální pozici enumerátoru. |
IEnumerator.Reset() |
Nastaví enumerátor na jeho počáteční pozici, která je před prvním prvkem v kolekci. |