Collection.GetEnumerator メソッド
アセンブリ: Microsoft.VisualBasic (microsoft.visualbasic.dll 内)

Dim instance As Collection Dim returnValue As IEnumerator returnValue = instance.GetEnumerator
public IEnumerator GetEnumerator ()
public: IEnumerator^ GetEnumerator ()
public IEnumerator GetEnumerator ()
public function GetEnumerator () : IEnumerator
Collection オブジェクト (Visual Basic) に対する反復処理に使用する、列挙子オブジェクトへの参照を返します。

詳細については、Visual Basic のトピック「GetEnumerator メソッド (コレクション オブジェクト)」を参照してください。
For Each...Next ステートメント (Visual Basic) は、GetEnumerator を呼び出して、コレクションの要素に対する反復処理をサポートする列挙子オブジェクトを取得します。通常は、For Each...Next ループを使用して、コレクションまたは配列を走査します。GetEnumerator を明示的に呼び出す必要はありません。
For Each...Next ステートメントによる制御よりも詳細な反復処理の制御が必要な場合は、GetEnumerator メソッドを使用して走査をカスタマイズできます。次のような場合に詳細な制御が必要です。

GetEnumerator を使用して Collection オブジェクトのすべての要素を取得する例を次に示します。
Dim customers As New Collection ' Insert code to add elements to the customers collection. Dim custEnum As IEnumerator = customers.GetEnumerator() custEnum.Reset() Dim thisCustomer As Object While custEnum.MoveNext() thisCustomer = custEnum.Current() ' Insert code to process this element of the collection. End While
GetEnumerator は、列挙子オブジェクトを構築して返します。列挙子オブジェクトは、System.Collections 名前空間の IEnumerator インターフェイスを実装します。列挙子オブジェクトは、Current プロパティと、MoveNext メソッドおよび Reset メソッドを公開します。詳細については、「For Each...Next ステートメント (Visual Basic)」を参照してください。

Windows 98, Windows 2000 SP4, Windows CE, Windows Millennium Edition, Windows Mobile for Pocket PC, Windows Mobile for Smartphone, Windows Server 2003, Windows XP Media Center Edition, Windows XP Professional x64 Edition, Windows XP SP2, Windows XP Starter Edition
開発プラットフォームの中には、.NET Framework によってサポートされていないバージョンがあります。サポートされているバージョンについては、「システム要件」を参照してください。


Collection.GetEnumerator メソッド
アセンブリ: mscorlib (mscorlib.dll 内)

Dim instance As Collection(Of T) Dim returnValue As IEnumerator(Of T) returnValue = instance.GetEnumerator
public IEnumerator<T> GetEnumerator ()
public: virtual IEnumerator<T>^ GetEnumerator () sealed
public final IEnumerator<T> GetEnumerator ()
public final function GetEnumerator () : IEnumerator<T>
Collection の IEnumerator。

C# 言語の foreach ステートメント (C++ の場合は for each、Visual Basic の場合は For Each) を使用することで列挙子の複雑さを回避できます。したがって、列挙子を直接操作するのではなく、foreach の使用をお勧めします。
列挙子を使用すると、コレクション内のデータを読み取ることができますが、基になるコレクションを変更することはできません。
最初に、列挙子はコレクションの最初の要素の前に配置されます。この位置では、Current が未定義です。したがって、Current の値を読み取る前に、MoveNext を呼び出して、コレクションの最初の要素に列挙子を進める必要があります。
Current は、MoveNext が呼び出されるまでは同じオブジェクトを返します。MoveNext は、Current を次の要素に設定します。
MoveNext がコレクションの末尾を過ぎると、列挙子はコレクションの最後の要素の後ろに配置され、MoveNext は false を返します。列挙子がこの位置にある場合、以降、MoveNext を呼び出しても false が返されます。MoveNext への最後の呼び出しで false が返された場合は、Current が未定義です。Current を、再度、コレクションの最初の要素に設定することはできません。列挙子の新しいインスタンスを作成する必要があります。
コレクションが変更されない限り、列挙子は有効なままです。要素の追加、変更、削除などの変更がコレクションに対して実行されると、列挙子は回復不可能な無効状態になり、動作は未定義になります。
列挙子はコレクションへの排他アクセス権を持たないため、コレクションの列挙処理は、本質的にはスレッド セーフな処理ではありません。すべての列挙処理が終わるまでコレクションをロックすることにより、列挙処理でのスレッド セーフを確保できます。コレクションに対し複数のスレッドがアクセスして読み取りや書き込みを行うことができるようにするには、独自に同期化を実装する必要があります。

Windows 98, Windows 2000 SP4, Windows CE, Windows Millennium Edition, Windows Mobile for Pocket PC, Windows Mobile for Smartphone, Windows Server 2003, Windows XP Media Center Edition, Windows XP Professional x64 Edition, Windows XP SP2, Windows XP Starter Edition
開発プラットフォームの中には、.NET Framework によってサポートされていないバージョンがあります。サポートされているバージョンについては、「システム要件」を参照してください。


Collection ジェネリック クラス
Collection メンバ
System.Collections.ObjectModel 名前空間
IEnumerator ジェネリック インターフェイス
- Collection.GetEnumeratorのページへのリンク