Dictionary<TKey,TValue>.GetEnumerator Metod
Definition
Viktigt
En del information gäller för förhandsversionen av en produkt och kan komma att ändras avsevärt innan produkten blir allmänt tillgänglig. Microsoft lämnar inga garantier, uttryckliga eller underförstådda, avseende informationen som visas här.
Returnerar en uppräkning som itererar genom Dictionary<TKey,TValue>.
public:
System::Collections::Generic::Dictionary<TKey, TValue>::Enumerator GetEnumerator();
public System.Collections.Generic.Dictionary<TKey,TValue>.Enumerator GetEnumerator();
member this.GetEnumerator : unit -> System.Collections.Generic.Dictionary<'Key, 'Value>.Enumerator
Public Function GetEnumerator () As Dictionary(Of TKey, TValue).Enumerator
Returer
En Dictionary<TKey,TValue>.Enumerator struktur för Dictionary<TKey,TValue>.
Kommentarer
För uppräkning är varje objekt en KeyValuePair<TKey,TValue> struktur som representerar ett värde och dess nyckel.
foreach-instruktionen för C#-språket (For Each i Visual Basic) döljer komplexiteten hos uppräknare. Därför rekommenderas användning foreach i stället för att direkt manipulera uppräknaren.
Uppräknare kan användas för att läsa data i samlingen, men de kan inte användas för att ändra den underliggande samlingen.
Inledningsvis placeras uppräknaren före det första elementet i samlingen. I det här läget Current är det odefinierat. Du måste anropa MoveNext metoden för att flytta uppräknaren till det första elementet i samlingen innan du läser värdet Currentför .
Egenskapen Current returnerar samma element tills MoveNext metoden anropas. MoveNext anger Current till nästa element.
Om MoveNext skickar slutet av samlingen placeras uppräknaren efter det sista elementet i samlingen och MoveNext returnerar false. När uppräknaren befinner sig på den här positionen returnerar falseefterföljande anrop MoveNext även . Om det sista anropet som MoveNext returnerades Currentfalseär odefinierat. Du kan inte ange Current det första elementet i samlingen igen. Du måste skapa en ny uppräkningsinstans i stället.
En uppräkning förblir giltig så länge samlingen förblir oförändrad. Om ändringar görs i samlingen, till exempel att lägga till element eller ändra kapaciteten, ogiltigförklaras uppräknaren oåterkalleligen och nästa anrop till MoveNext eller IEnumerator.Reset genererar en InvalidOperationException.
endast .NET Core 3.0+ : De enda muterande metoderna som inte ogiltigförklarar uppräknare är Remove och Clear.
Uppräknaren har inte exklusiv åtkomst till samlingen. Därför är uppräkning genom en samling i sig inte en trådsäker procedur. För att garantera trådsäkerheten under uppräkningen kan du låsa samlingen under hela uppräkningen. Om du vill att samlingen ska kunna nås av flera trådar för läsning och skrivning måste du implementera din egen synkronisering.
Standardimplementeringar av samlingar i System.Collections.Generic namnområdet synkroniseras inte.
Den här metoden är en O(1)-åtgärd.