Dictionary<TKey,TValue>.KeyCollection.Enumerator Структура
Определение
Важно!
Некоторые сведения относятся к предварительной версии продукта, в которую до выпуска могут быть внесены существенные изменения. Майкрософт не предоставляет никаких гарантий, явных или подразумеваемых, относительно приведенных здесь сведений.
Выполняет перечисление элементов коллекции 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
[<System.Serializable>]
type Dictionary<'Key, 'Value>.KeyCollection.Enumerator = struct
interface IEnumerator<'Key>
interface IEnumerator
interface IDisposable
Public Structure Dictionary(Of TKey, TValue).KeyCollection.Enumerator
Implements IEnumerator(Of TKey)
Параметры типа
- TKey
- TValue
- Наследование
- Атрибуты
- Реализации
Комментарии
Оператор foreach
языка C# (for each
в C++, For Each
в Visual Basic) скрывает сложность перечислителей. Поэтому рекомендуется вместо непосредственного использования перечислителя применять ключевое слово foreach
.
Перечислители могут использоваться для чтения данных в коллекции, но не для ее изменения.
Изначально перечислитель располагается перед первым элементом коллекции. В этой позиции значение свойства Current не определено. Перед чтением значения Currentнеобходимо вызвать MoveNext перечислитель к первому элементу коллекции.
Current возвращает тот же объект, пока не будет вызван метод MoveNext. MoveNext задает Current в качестве значения для следующего элемента.
Если MoveNext передает конец коллекции, перечислитель позиционируется после последнего элемента в коллекции и MoveNext возвращается false
. Если перечислитель находится в этой позиции, последующие вызовы MoveNext для возврата false
также. Если последний обратный вызов MoveNext возвращен false
, Current не определен. Значение свойства Current не может быть повторно задано первому элементу коллекции; вместо этого следует создать новый экземпляр перечислителя.
Перечислитель является допустимым до тех пор, пока коллекция остается неизменной. Если в коллекцию вносятся изменения, например добавление элементов или изменение емкости, перечислитель неустранимо недействительным, а следующий вызов MoveNext или IEnumerator.Reset вызов вызывает исключение InvalidOperationException.
Только .NET Core 3.0+ — единственные методы, которые не являются недействительными перечислителямиRemove.Clear
У перечислителя нет эксклюзивного доступа к коллекции, поэтому перечисление коллекции не является потокобезопасной процедурой. Чтобы гарантировать потокобезопасность, можно заблокировать коллекцию на время всего перечисления. Чтобы разрешить доступ к коллекции из нескольких потоков для чтения и записи, необходимо реализовать собственную синхронизацию.
Реализации коллекций по умолчанию не System.Collections.Generic синхронизируются.
Свойства
Current |
Возвращает элемент, расположенный в текущей позиции перечислителя. |
Методы
Dispose() |
Освобождает все ресурсы, занятые модулем Dictionary<TKey,TValue>.KeyCollection.Enumerator. |
MoveNext() |
Перемещает перечислитель к следующему элементу коллекции Dictionary<TKey,TValue>.KeyCollection. |
Явные реализации интерфейса
IEnumerator.Current |
Возвращает элемент, расположенный в текущей позиции перечислителя. |
IEnumerator.Reset() |
Устанавливает перечислитель в его начальное положение, т. е. перед первым элементом коллекции. |