Dictionary<TKey,TValue>.IDictionary.GetEnumerator Dictionary<TKey,TValue>.IDictionary.GetEnumerator Dictionary<TKey,TValue>.IDictionary.GetEnumerator Method

Definizione

 virtual System::Collections::IDictionaryEnumerator ^ System.Collections.IDictionary.GetEnumerator() = System::Collections::IDictionary::GetEnumerator;
System.Collections.IDictionaryEnumerator IDictionary.GetEnumerator ();
Function GetEnumerator () As IDictionaryEnumerator Implements IDictionary.GetEnumerator

Restituisce

Implementazioni

Esempi

Esempio di codice seguente viene illustrato come enumerare le coppie chiave/valore nel dizionario usando il foreach istruzione (For Each in Visual Basic for each in C++), che consente di nascondere l'uso dell'enumeratore.The following code example shows how to enumerate the key/value pairs in the dictionary by using the foreach statement (For Each in Visual Basic, for each in C++), which hides the use of the enumerator. In particolare, si noti che l'enumeratore per il System.Collections.IDictionary interfaccia restituisce DictionaryEntry oggetti anziché KeyValuePair<TKey,TValue> oggetti.In particular, note that the enumerator for the System.Collections.IDictionary interface returns DictionaryEntry objects rather than KeyValuePair<TKey,TValue> objects.

L'esempio di codice fa parte di un esempio più esaustivo, incluso l'output, fornito per il IDictionary.Add (metodo).The code example is part of a larger example, including output, provided for the IDictionary.Add method.

using System;
using System.Collections;
using System.Collections.Generic;

public class Example
{
    public static void Main()
    {
        // Create a new dictionary of strings, with string keys,
        // and access it using the IDictionary interface.
        //
        IDictionary openWith = new Dictionary<string, string>();

        // Add some elements to the dictionary. There are no 
        // duplicate keys, but some of the values are duplicates.
        // IDictionary.Add throws an exception if incorrect types
        // are supplied for key or value.
        openWith.Add("txt", "notepad.exe");
        openWith.Add("bmp", "paint.exe");
        openWith.Add("dib", "paint.exe");
        openWith.Add("rtf", "wordpad.exe");
Imports System
Imports System.Collections
Imports System.Collections.Generic

Public Class Example
    
    Public Shared Sub Main() 

        ' Create a new dictionary of strings, with string keys,
        ' and access it using the IDictionary interface.
        '
        Dim openWith As IDictionary = _
            New Dictionary(Of String, String)
        
        ' Add some elements to the dictionary. There are no 
        ' duplicate keys, but some of the values are duplicates.
        ' IDictionary.Add throws an exception if incorrect types
        ' are supplied for key or value.
        openWith.Add("txt", "notepad.exe")
        openWith.Add("bmp", "paint.exe")
        openWith.Add("dib", "paint.exe")
        openWith.Add("rtf", "wordpad.exe")
// When you use foreach to enumerate dictionary elements
// with the IDictionary interface, the elements are retrieved
// as DictionaryEntry objects instead of KeyValuePair objects.
Console.WriteLine();
foreach( DictionaryEntry de in openWith )
{
    Console.WriteLine("Key = {0}, Value = {1}", 
        de.Key, de.Value);
}
' When you use foreach to enumerate dictionary elements
' with the IDictionary interface, the elements are retrieved
' as DictionaryEntry objects instead of KeyValuePair objects.
Console.WriteLine()
For Each de As DictionaryEntry In openWith
    Console.WriteLine("Key = {0}, Value = {1}", _
        de.Key, de.Value)
Next 
    }
}

    End Sub

End Class

Commenti

Ai fini dell'enumerazione, ogni elemento è un DictionaryEntry struttura.For purposes of enumeration, each item is a DictionaryEntry structure.

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. Il Reset metodo riporta l'enumeratore in questa posizione.The Reset method also brings the enumerator back to this position. In questa posizione, la proprietà Entry è indefinita.At this position, Entry is undefined. Pertanto, è necessario chiamare il MoveNext per passare l'enumeratore al primo elemento della raccolta prima di leggere il valore del metodo Entry.Therefore, you must call the MoveNext method to advance the enumerator to the first element of the collection before reading the value of Entry.

Il Entry proprietà restituisce lo stesso elemento finché non la MoveNext o Reset viene chiamato il metodo.The Entry property returns the same element until either the MoveNext or Reset method is called. MoveNext imposta Entry sull'elemento successivo.MoveNext sets Entry 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, Entry è definito.If the last call to MoveNext returned false, Entry is undefined. Per impostare nuovamente la proprietà Entry sul primo elemento della raccolta, è possibile chiamare il metodo Reset seguito da MoveNext.To set Entry to the first element of the collection again, you can call Reset followed by MoveNext.

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 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 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.

Questo metodo è un'operazione o (1).This method is an O(1) operation.

Si applica a

Vedi anche