SortedDictionary<TKey,TValue>.GetEnumerator Metoda
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í.
Vrátí enumerátor, který iteruje přes SortedDictionary<TKey,TValue>.
public:
System::Collections::Generic::SortedDictionary<TKey, TValue>::Enumerator GetEnumerator();
public System.Collections.Generic.SortedDictionary<TKey,TValue>.Enumerator GetEnumerator ();
member this.GetEnumerator : unit -> System.Collections.Generic.SortedDictionary<'Key, 'Value>.Enumerator
Public Function GetEnumerator () As SortedDictionary(Of TKey, TValue).Enumerator
Návraty
A SortedDictionary<TKey,TValue>.Enumerator pro SortedDictionary<TKey,TValue>.
Poznámky
Pro účely výčtu je každá položka strukturou KeyValuePair<TKey,TValue> představující hodnotu a její klíč.
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žívat 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.
Slovník se udržuje v seřazeném pořadí pomocí interního stromu. Každý nový prvek je umístěn na správné pozici řazení a strom je upraven tak, aby zachoval pořadí řazení při každém odebrání prvku. Při vytváření výčtu je pořadí řazení zachováno.
Zpočátku je enumerátor umístěn před prvním prvkem v kolekci. V této pozici Current je vlastnost nedefinovaná. Proto je nutné volat metodu MoveNext pro přechod enumerátoru na první prvek kolekce před čtením hodnoty Current.
Vlastnost Current vrátí stejný prvek, dokud MoveNext není volána metoda. MoveNext nastaví Current na další prvek.
Pokud MoveNext přejde na konec kolekce, enumerátor se umístí za poslední prvek v kolekci a MoveNext vrátí false
. Pokud je enumerátor na této pozici, další volání MoveNext vrátí false
také . 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 enumerátoru.
Enumerátor zůstane platný, dokud kolekce zůstane beze změny. Pokud jsou v kolekci provedeny změny, například přidání, úprava nebo odstranění prvků, je výčet nenávratně zneplatněný a další volání MoveNext nebo IEnumerator.Reset vyvolá InvalidOperationException.
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. Abyste zajistili bezpečnost vláken během výčtu, můžete kolekci uzamknout 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 System.Collections.Generic oboru názvů se nesynchronují.
Tato metoda je operace O(log n), kde n je počet.