Я знаю, как реализовать не общий IEnumerable, например:
using System;
using System.Collections;
namespace ConsoleApplication33
{
class Program
{
static void Main(string[] args)
{
MyObjects myObjects = new MyObjects();
myObjects[0] = new MyObject() { Foo = "Hello", Bar = 1 };
myObjects[1] = new MyObject() { Foo = "World", Bar = 2 };
foreach (MyObject x in myObjects)
{
Console.WriteLine(x.Foo);
Console.WriteLine(x.Bar);
}
Console.ReadLine();
}
}
class MyObject
{
public string Foo { get; set; }
public int Bar { get; set; }
}
class MyObjects : IEnumerable
{
ArrayList mylist = new ArrayList();
public MyObject this[int index]
{
get { return (MyObject)mylist[index]; }
set { mylist.Insert(index, value); }
}
IEnumerator IEnumerable.GetEnumerator()
{
return mylist.GetEnumerator();
}
}
}
Однако я также заметил, что IEnumerable имеет общую версию IEnumerable<T>
, но я не могу понять, как ее реализовать.
Если я добавлю using System.Collections.Generic;
к своим директивам using, а затем изменю:
class MyObjects : IEnumerable
чтобы:
class MyObjects : IEnumerable<MyObject>
Затем щелкните правой кнопкой мыши IEnumerable<MyObject>
и выберите Implement Interface => Implement Interface
, Visual Studio услужливо добавляет следующий блок кода:
IEnumerator<MyObject> IEnumerable<MyObject>.GetEnumerator()
{
throw new NotImplementedException();
}
Возврат неуниверсального объекта IEnumerable из GetEnumerator();
метода на этот раз не сработает, так что мне здесь указать? Интерфейс командной строки теперь игнорирует неуниверсальную реализацию и направляется прямо к общей версии, когда пытается выполнить перечисление через мой массив во время цикла foreach.
this.GetEnumerator()
и простым возвратом в неуниверсальной реализацииGetEnumerator()
?