IEnumerator.Reset メソッドとは? わかりやすく解説

IEnumerator.Reset メソッド

列挙子を初期位置、つまりコレクション最初要素前に設定します

名前空間: System.Collections
アセンブリ: mscorlib (mscorlib.dll 内)
構文構文

例外例外
例外種類条件

InvalidOperationException

列挙子が作成された後に、コレクション変更されました。

解説解説

コレクション変更されない限り列挙子は有効なままです。要素追加変更削除などの変更コレクションに対して実行されると、列挙子は回復不可能な無効状態になり、次に MoveNext メソッドまたは Reset メソッド呼び出すと InvalidOperationExceptionスローさます。

実装時の注意 Reset呼び出した場合結果として列挙子が必ず同じ状態になることが必要です。列挙子をコレクション先頭、つまり最初要素前に移動する実装がよく使用されます。この場合列挙子が作成され後でコレクション変更されていると、その列挙子は無効になります。これは、MoveNext および Current使用する場合でも同様です

使用例使用例

カスタム コレクションでの IEnumerator インターフェイス実装次のコード例示します。この例では、Reset明示的に呼び出されていませんが、foreach (Visual Basic では for each) の使用サポートするために実装されています。このコード例は、IEnumerator インターフェイストピック取り上げているコード例一部です。

Public Class PeopleEnum
    Implements IEnumerator

    Public _people() As Person

    ' Enumerators are positioned before the first element
    ' until the first MoveNext() call.
    Dim position As Integer
 = -1

    Public Sub New(ByVal
 list() As Person)
        _people = list
    End Sub

    Public Function MoveNext() As
 Boolean Implements IEnumerator.MoveNext
        position = position + 1
        Return (position < _people.Length)
    End Function

    Public Sub Reset() Implements
 IEnumerator.Reset
        position = -1
    End Sub

    Public ReadOnly Property
 Current() As Object Implements
 IEnumerator.Current
        Get
            Try
                Return _people(position)
            Catch ex As IndexOutOfRangeException
                Throw New InvalidOperationException()
            End Try
        End Get
    End Property
End Class
public class PeopleEnum : IEnumerator
{
    public Person[] _people;

    // Enumerators are positioned before the first element
    // until the first MoveNext() call.
    int position = -1;

    public PeopleEnum(Person[] list)
    {
        _people = list;
    }

    public bool MoveNext()
    {
        position++;
        return (position < _people.Length);
    }

    public void Reset()
    {
        position = -1;
    }

    public object Current
    {
        get
        {
            try
            {
                return _people[position];
            }
            catch (IndexOutOfRangeException)
            {
                throw new InvalidOperationException();
            }
        }
    }
}
プラットフォームプラットフォーム
バージョン情報バージョン情報
参照参照



英和和英テキスト翻訳>> Weblio翻訳
英語⇒日本語日本語⇒英語
  

辞書ショートカット

すべての辞書の索引

「IEnumerator.Reset メソッド」の関連用語











IEnumerator.Reset メソッドのお隣キーワード
検索ランキング

   

英語⇒日本語
日本語⇒英語
   



IEnumerator.Reset メソッドのページの著作権
Weblio 辞書 情報提供元は 参加元一覧 にて確認できます。

   
日本マイクロソフト株式会社日本マイクロソフト株式会社
© 2024 Microsoft.All rights reserved.

©2024 GRAS Group, Inc.RSS