IEnumerator Rozhraní

Definice

Podporuje jednoduchou iteraci v negenerické kolekci.

public interface IEnumerator
[System.Runtime.InteropServices.Guid("496B0ABF-CDEE-11d3-88E8-00902754C43A")]
public interface IEnumerator
[System.Runtime.InteropServices.Guid("496B0ABF-CDEE-11d3-88E8-00902754C43A")]
[System.Runtime.InteropServices.ComVisible(true)]
public interface IEnumerator
Odvozené
Atributy

Příklady

Následující příklad kódu ukazuje implementaci IEnumerable a IEnumerator rozhraní pro vlastní kolekci. V tomto příkladu nejsou členy těchto rozhraní explicitně volány, ale implementují se pro podporu použití foreach (for each v jazyce Visual Basic) k iteraci prostřednictvím kolekce.

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()
    {
        position++;
        return (position < _people.Length);
    }

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

    object IEnumerator.Current
    {
        get
        {
            return Current;
        }
    }

    public Person Current
    {
        get
        {
            try
            {
                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
 *
 */

Poznámky

IEnumerator je základní rozhraní pro všechny ne generické enumerátory. Jeho obecný ekvivalent je rozhraní System.Collections.Generic.IEnumerator<T>.

Příkaz foreach jazyka C# (for each v jazyce Visual Basic) skrývá složitost výčtů. Proto se místo přímé manipulace s enumerátorem doporučuje použití foreach.

Enumerátory lze použít ke čtení dat v kolekci, ale nelze je použít k úpravě podkladové kolekce.

Metoda Reset je poskytována pro interoperabilitu modelu COM a není nutné ji plně implementovat; implementátor může vyvolat NotSupportedException.

Na začátku je enumerátor umístěn před prvním prvkem v kolekci. Před čtením hodnoty Currentje nutné volat metodu MoveNext, která předčítá enumerátor na první prvek kolekce; jinak Current není definováno.

Current vrátí stejný objekt, dokud se nevolá MoveNext nebo Reset. MoveNext nastaví Current na další prvek.

Pokud MoveNext předá konec kolekce, enumerátor se umístí za poslední prvek kolekce a MoveNext vrátí false. Pokud je enumerátor na této pozici, následná volání MoveNext vrátí také false. Pokud se poslední volání MoveNext vrátilo false, Current není definováno.

Chcete-li nastavit Current na první prvek kolekce znovu, můžete volat Reset, pokud je implementována, následované MoveNext. Pokud Reset není implementováno, je nutné vytvořit novou instanci enumerátoru, která se vrátí k prvnímu prvku kolekce.

Pokud jsou v kolekci provedeny změny, například přidání, úpravy nebo odstranění prvků, chování enumerátoru není definováno.

Enumerátor nemá výhradní přístup k kolekci; proto výčet prostřednictvím kolekce není vnitřně bezpečným postupem pro přístup z více vláken. I když je kolekce synchronizována, ostatní vlákna mohou stále upravovat kolekci, což způsobí, že enumerátor vyvolá výjimku. Chcete-li zaručit bezpečnost vláken během výčtu, můžete buď uzamknout kolekci během celého výčtu, nebo zachytit výjimky vyplývající z změn provedených jinými vlákny.

Vlastnosti

Current

Získá prvek v kolekci na aktuální pozici enumerátoru.

Metody

MoveNext()

Přejde enumerátor na další prvek kolekce.

Reset()

Nastaví enumerátor na počáteční pozici, která je před prvním prvkem v kolekci.

Platí pro

Produkt Verze
.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 1.1, 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.5, 1.6, 2.0, 2.1
UWP 10.0

Viz také