SortedDictionary<TKey,TValue>.ValueCollection.Enumerator 结构

定义

C#
public struct SortedDictionary<TKey,TValue>.ValueCollection.Enumerator : System.Collections.Generic.IEnumerator<TValue>

类型参数

TKey
TValue
继承
SortedDictionary<TKey,TValue>.ValueCollection.Enumerator
实现

注解

foreach Visual Basic) for each C++ For Each 中 C# (的语句隐藏枚举器的复杂性。 因此,建议使用 foreach,而不是直接操作枚举数。 此类型实现 IEnumerator<T> 接口。

枚举器可用于读取集合中的数据,但不能用于修改基础集合。

最初,枚举数定位在集合中第一个元素的前面。 在此位置上,未定义 Current。 在读取 的值Current之前,MoveNext必须调用 方法,将枚举数推进到集合的第一个元素。

Current 调用 之前 MoveNext , 属性返回相同的 对象。 MoveNextCurrent 设置为下一个元素。

如果 MoveNext 传递集合的末尾,则枚举器位于集合中最后一个元素之后,并 MoveNext 返回 false。 当枚举器位于此位置时,对 MoveNext 的后续调用也会返回 false。 如果最后一次MoveNext调用返回 ,falseCurrent则为未定义。 无法再次将 Current 设置为集合的第一个元素;必须改为创建新的枚举器实例。

只要集合保持不变,枚举器就仍有效。 如果对集合进行了更改(例如添加、修改或删除元素),枚举器将不可恢复地失效,并且对 或 IEnumerator.Reset 的下一次InvalidOperationException调用MoveNext将引发 。

枚举数没有对集合的独占访问权;因此,从头到尾对一个集合进行枚举在本质上不是一个线程安全的过程。 若要确保枚举过程中的线程安全性,可以在整个枚举过程中锁定集合。 若要允许多个线程访问集合以进行读写操作,则必须实现自己的同步。

System.Collections.Generic 命名空间中集合的默认实现是不同步的。

属性

Current

获取枚举数当前位置的元素。

方法

Dispose()

释放由 SortedDictionary<TKey,TValue>.ValueCollection.Enumerator 使用的所有资源。

MoveNext()

使枚举数前进到 SortedDictionary<TKey,TValue>.ValueCollection 的下一个元素。

显式接口实现

IEnumerator.Current

获取枚举数当前位置的元素。

IEnumerator.Reset()

将枚举数设置为其初始位置,该位置位于集合中第一个元素之前。

适用于

产品 版本
.NET Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Framework 2.0, 3.0, 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
.NET Standard 1.0, 1.1, 1.2, 1.3, 1.4, 1.6, 2.0, 2.1
UWP 10.0

另请参阅