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

Определение

Возвращает перечислитель IDictionaryEnumerator для словаря IDictionary.Returns an IDictionaryEnumerator for the IDictionary.

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

Возвраты

Реализации

Примеры

В следующем примере кода показано, как перечислить пары "ключ-значение" в словаре с foreach помощью инструкцииFor Each (в Visual Basic for each , C++в), которая скрывает использование перечислителя.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. В частности, обратите внимание, что перечислитель System.Collections.IDictionary для DictionaryEntry интерфейса возвращает объекты KeyValuePair<TKey,TValue> , а не объекты.In particular, note that the enumerator for the System.Collections.IDictionary interface returns DictionaryEntry objects rather than KeyValuePair<TKey,TValue> objects.

Пример кода является частью более крупного примера, включая выходные данные, предоставленные для IDictionary.Add метода.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.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

Комментарии

В целях перечисления каждый элемент является DictionaryEntry структурой.For purposes of enumeration, each item is a DictionaryEntry structure.

foreach Оператор C# языка(for each C++в VisualBasic)скрываетсложностьперечислителей.For EachThe foreach statement of the C# language (for each in C++, For Each in Visual Basic) hides the complexity of enumerators. Поэтому рекомендуется вместо непосредственного использования перечислителя применять ключевое слово foreach.Therefore, using foreach is recommended, instead of directly manipulating the enumerator.

Перечислители могут использоваться для чтения данных в коллекции, но не для ее изменения.Enumerators can be used to read the data in the collection, but they cannot be used to modify the underlying collection.

Изначально перечислитель располагается перед первым элементом коллекции.Initially, the enumerator is positioned before the first element in the collection. Reset Метод также переводит перечислитель обратно в эту точку.The Reset method also brings the enumerator back to this position. В этой позиции значение свойства Entry не определено.At this position, Entry is undefined. Поэтому необходимо вызвать MoveNext метод, чтобы переместить перечислитель к первому элементу коллекции перед считыванием 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.

Свойство возвращает один и тот же элемент до тех MoveNext пор, пока не будет вызван метод или Reset. EntryThe Entry property returns the same element until either the MoveNext or Reset method is called. MoveNext задает Entry в качестве значения для следующего элемента.MoveNext sets Entry to the next element.

Если MoveNext передает конец коллекции, перечислитель располагается после последнего элемента в коллекции и MoveNext возвращает false.If MoveNext passes the end of the collection, the enumerator is positioned after the last element in the collection and MoveNext returns false. Если перечислитель находится в этой позиции, последующие вызовы MoveNext также возвращают. falseWhen the enumerator is at this position, subsequent calls to MoveNext also return false. Если последний вызов MoveNext возвращен false, Entry значение не определено.If the last call to MoveNext returned false, Entry is undefined. Чтобы снова задать в качестве значения свойства Entry первый элемент коллекции, можно последовательно вызвать методы Reset иMoveNext.To set Entry to the first element of the collection again, you can call Reset followed by MoveNext.

Перечислитель остается действительным, пока коллекция не изменяется.An enumerator remains valid as long as the collection remains unchanged. Если в коллекцию вносятся изменения, такие как добавление, изменение или удаление элементов, перечислитель становится необратимо недействительным, а следующий вызов MoveNext или Reset вызывает 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.

У перечислителя нет эксклюзивного доступа к коллекции, поэтому перечисление коллекции не является потокобезопасной процедурой.The enumerator does not have exclusive access to the collection; therefore, enumerating through a collection is intrinsically not a thread-safe procedure. Чтобы гарантировать потокобезопасность, можно заблокировать коллекцию на время всего перечисления.To guarantee thread safety during enumeration, you can lock the collection during the entire enumeration. Чтобы разрешить доступ к коллекции из нескольких потоков для чтения и записи, необходимо реализовать собственную синхронизацию.To allow the collection to be accessed by multiple threads for reading and writing, you must implement your own synchronization.

Используемые по умолчанию реализации коллекций в пространстве имен System.Collections.Generic не синхронизированы.Default implementations of collections in the System.Collections.Generic namespace are not synchronized.

Этот метод является операцией O (1).This method is an O(1) operation.

Применяется к

Дополнительно