IEnumerator 인터페이스


제네릭이 아닌 컬렉션을 단순하게 반복할 수 있도록 지원합니다.Supports a simple iteration over a non-generic collection.

public interface class IEnumerator
public interface IEnumerator
public interface IEnumerator
public interface IEnumerator
type IEnumerator = interface
type IEnumerator = interface
type IEnumerator = interface
Public Interface IEnumerator


다음 코드 예제에서는 IEnumerable IEnumerator 사용자 지정 컬렉션에 대 한 및 인터페이스의 구현을 보여 줍니다.The following code example demonstrates the implementation of the IEnumerable and IEnumerator interfaces for a custom collection. 이 예제에서는 이러한 인터페이스의 멤버를 명시적으로 호출 하지는 않지만 foreach (Visual Basic)를 사용 하 여 컬렉션을 반복할 수 있도록 구현 됩니다 for each .In this example, members of these interfaces are not explicitly called, but they are implemented to support the use of foreach (for each in Visual Basic) to iterate through the collection.

using System;
using System.Collections;

// Simple business object.
public class Person
    public Person(string fName, string lName)
        this.firstName = fName;
        this.lastName = lName;

    public string firstName;
    public string lastName;

// Collection of Person objects. This class
// implements IEnumerable so that it can be used
// with ForEach syntax.
public class People : IEnumerable
    private Person[] _people;
    public People(Person[] pArray)
        _people = new Person[pArray.Length];

        for (int i = 0; i < pArray.Length; i++)
            _people[i] = pArray[i];

// Implementation for the GetEnumerator method.
    IEnumerator IEnumerable.GetEnumerator()
       return (IEnumerator) GetEnumerator();

    public PeopleEnum GetEnumerator()
        return new PeopleEnum(_people);

// When you implement IEnumerable, you must also implement IEnumerator.
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()
        return (position < _people.Length);

    public void Reset()
        position = -1;

    object IEnumerator.Current
            return Current;

    public Person Current
                return _people[position];
            catch (IndexOutOfRangeException)
                throw new InvalidOperationException();

class App
    static void Main()
        Person[] peopleArray = new Person[3]
            new Person("John", "Smith"),
            new Person("Jim", "Johnson"),
            new Person("Sue", "Rabon"),

        People peopleList = new People(peopleArray);
        foreach (Person p in peopleList)
            Console.WriteLine(p.firstName + " " + p.lastName);

/* This code produces output similar to the following:
 * John Smith
 * Jim Johnson
 * Sue Rabon
Imports System.Collections

' Simple business object.
Public Class Person

    Public Sub New(ByVal fName As String, ByVal lName As String)
        Me.firstName = fName
        Me.lastName = lName
    End Sub

    Public firstName As String
    Public lastName As String
End Class

' Collection of Person objects, which implements IEnumerable so that
' it can be used with ForEach syntax.
Public Class People
    Implements IEnumerable

    Private _people() As Person

    Public Sub New(ByVal pArray() As Person)
        _people = New Person(pArray.Length - 1) {}

        Dim i As Integer
        For i = 0 To pArray.Length - 1
            _people(i) = pArray(i)
        Next i
    End Sub

    ' Implementation of GetEnumerator.
    Public Function GetEnumerator() As IEnumerator _
      Implements IEnumerable.GetEnumerator

        Return New PeopleEnum(_people)
    End Function

End Class

' When you implement IEnumerable, you must also implement 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
                Return _people(position)
            Catch ex As IndexOutOfRangeException
                Throw New InvalidOperationException()
            End Try
        End Get
    End Property
End Class

Class App
    Shared Sub Main()
        Dim peopleArray() As Person = { _
            New Person("John", "Smith"), _
            New Person("Jim", "Johnson"), _
            New Person("Sue", "Rabon")}

        Dim peopleList As New People(peopleArray)
        Dim p As Person
        For Each p In peopleList
            Console.WriteLine(p.firstName + " " + p.lastName)

    End Sub
End Class

' This code produces output similar to the following:
' John Smith
' Jim Johnson
' Sue Rabon


IEnumerator 는 제네릭이 아닌 모든 열거자의 기본 인터페이스입니다.IEnumerator is the base interface for all non-generic enumerators. 이에 해당 하는 제네릭 System.Collections.Generic.IEnumerator<T> 인터페이스는 인터페이스입니다.Its generic equivalent is the System.Collections.Generic.IEnumerator<T> interface.

@FSHO1@C# 언어의 foreach 문(Visual Basic의 경우 for each)은 열거자의 복잡성을 숨깁니다.The foreach statement of the C# language (for each in Visual Basic) hides the complexity of the 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.

Reset메서드는 COM 상호 운용성을 위해 제공 되며 완전히 구현할 필요는 없습니다. 대신 구현자는을 throw 할 수 있습니다 NotSupportedException .The Reset method is provided for COM interoperability and does not need to be fully implemented; instead, the implementer can throw a NotSupportedException.

처음에 열거자는 컬렉션의 첫 번째 요소 앞에 배치됩니다.Initially, the enumerator is positioned before the first element in the collection. MoveNext의 값을 읽기 전에 메서드를 호출 하 여 열거자를 컬렉션의 첫 번째 요소로 이동 해야 합니다. Current 그렇지 않으면 Current 가 정의 되지 않습니다.You must call the MoveNext method to advance the enumerator to the first element of the collection before reading the value of Current; otherwise, Current is undefined.

Current에서는 MoveNext 또는 Reset이 호출될 때까지 동일한 개체를 반환합니다.Current returns the same object until either MoveNext or Reset is called. MoveNextCurrent를 다음 요소로 설정합니다.MoveNext sets Current 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 반환할 수도 false합니다.When the enumerator is at this position, subsequent calls to MoveNext also return false. 에 대 한 마지막 호출이 MoveNext false 정의 되어 있지 않으면이 반환 Current 됩니다.If the last call to MoveNext returned false, Current is undefined.

Current 컬렉션의 첫 번째 요소로 다시 설정 하려면가 구현 된 경우를 호출 하 고 그 뒤에를 호출 하면 Reset MoveNext 됩니다.To set Current to the first element of the collection again, you can call Reset, if it's implemented, followed by MoveNext. Reset가 구현 되지 않은 경우에는 컬렉션의 첫 번째 요소로 돌아갈 새 열거자 인스턴스를 만들어야 합니다.If Reset is not implemented, you must create a new enumerator instance to return to the first element of the collection.

요소 추가, 수정 또는 삭제와 같이 컬렉션이 변경 되 면 열거자의 동작이 정의 되지 않습니다.If changes are made to the collection, such as adding, modifying, or deleting elements, the behavior of the enumerator is undefined.

열거자는 컬렉션에 배타적으로 액세스하지 못하므로 컬렉션을 열거하는 것은 본질적으로 스레드로부터 안전한 프로시저가 아닙니다.The enumerator does not have exclusive access to the collection; therefore, enumerating through a collection is intrinsically not a thread-safe procedure. 컬렉션이 동기화되어 있을 때 다른 스레드에서 해당 컬렉션을 수정할 수 있으므로 이렇게 되면 열거자에서 예외가 throw됩니다.Even when a collection is synchronized, other threads can still modify the collection, which causes the enumerator to throw an exception. 열거하는 동안 스레드로부터 안전을 보장하려면 전체 열거를 수행하는 동안 컬렉션을 잠그거나 다른 스레드에서 변경된 내용으로 인해 발생한 예외를 catch하면 됩니다.To guarantee thread safety during enumeration, you can either lock the collection during the entire enumeration or catch the exceptions resulting from changes made by other threads.



컬렉션에서 열거자의 현재 위치에 있는 요소를 가져옵니다.Gets the element in the collection at the current position of the enumerator.



열거자를 컬렉션의 다음 요소로 이동합니다.Advances the enumerator to the next element of the collection.


컬렉션의 첫 번째 요소 앞의 초기 위치에 열거자를 설정합니다.Sets the enumerator to its initial position, which is before the first element in the collection.

적용 대상

추가 정보