0

GetEnumerator cast to an Interface failed
没有编译器错误
运行时失败,消息索引无穷大
如果我直接使用 struct Word1252 而没有接口,它可以工作

namespace WordEnumerable
{
    public partial class MainWindow : Window
    {
        public MainWindow()
        {
            InitializeComponent();
            WordEnum wordEnum = new WordEnum();
            Debug.WriteLine(wordEnum[0].GetType().ToString());
            Debug.WriteLine(wordEnum[0].Value);
            Debug.WriteLine(wordEnum.Count.ToString());
            foreach (iWord w in wordEnum)  // fails here
            {
            }
        }
    }
}
public interface iWord
{
    Int32 Key { get; }
    String Value { get; }
}
public class WordEnum : IEnumerable<iWord>
{
    private static List<Word1252> words1252 = new List<Word1252>();
    IEnumerator<iWord> IEnumerable<iWord>.GetEnumerator()
    {
        return ((IEnumerable<iWord>)words1252).GetEnumerator();
    }
    public struct Word1252 : iWord
    {
        public UInt64 packed;
        public Int32 Key   { get { return (Int32)((packed >> 27) & ((1 << 25) - 1)); } }
        public Byte Length { get { return (Byte) ((packed >> 59) & ((1 <<  5) - 1)); } }
        public String Value { get { return Key.ToString(); } }
        public Word1252(UInt64 Packed) { packed = Packed; }
    }
4

1 回答 1

1

简而言之,upcastingIEnumerable<Word1252>IEnumerable<IWord>

这需要covariance工作。

即使 IEnumerable 被标记为out(协变)
协方差也不适用于“值类型” ——即您定义了接口的结构。

例如看...

这是 C# 4 中的协方差错误吗?
(或有点不同,但归结为同一个问题)
为什么不能将 IEnumerable<struct> 转换为 IEnumerable<object>?

要解决,您只需定义您的列表,例如

private static List<iWord> words1252 = new List<iWord>();  

或者像这样定义你的枚举器:

IEnumerator<iWord> IEnumerable<iWord>.GetEnumerator()
{
    foreach (var word in words1252)
        yield return word;
}
于 2013-04-20T23:21:19.807 回答