当前位置:  开发笔记 > 编程语言 > 正文

为什么(IEnumerable <SomeThing>类型的变量).GetType().GetGenericArgsuments().Count()是两个而不是一个?

如何解决《为什么(IEnumerable<SomeThing>类型的变量).GetType().GetGenericArgsuments().Count()是两个而不是一个?》经验,为你挑选了1个好方法。

看看下面的代码:

为什么result1有2个通用参数?

    public class Program
    {
        public static void Main(string[] args)
        {
            IEnumerable result1 = Test1();
            Console.WriteLine(result1.GetType().GetGenericArguments().Count()); // 2

            IEnumerable result2 = Test2();
            Console.WriteLine(result2.GetType().GetGenericArguments().Count()); // 1
        }

        public static IEnumerable Test1()
        {
            return new Test[] { }.Where(t => t.Id > 1).Select(t =>
            {
                t.Id++;
                return t;
            });
        }

        public static IEnumerable Test2()
        {
            return new Test[] { }.Where(t => t.Id > 1);
        }
    }

    public class Test
    {
        public virtual int Id { get; set; }
    }

tyranid.. 7

这是因为从Test1返回的是WhereSelectArrayIterator的一个实例,它接受两个通用参数,一个源类型和一个结果类型.即class WhereSelectArrayIterator或参见参考源.

但是,类本身实现了IEnumerable ,它允许将它分配给您的变量.您所犯的错误是将可分配类型(IEnumerable )与实现类型(WhereSelectArrayInterator)混淆.当你只有一个where语句时,只有一个泛型类型,因为它不会将类型从源转换为结果.

在这种情况下,打印类型的名称将给你答案.



1> tyranid..:

这是因为从Test1返回的是WhereSelectArrayIterator的一个实例,它接受两个通用参数,一个源类型和一个结果类型.即class WhereSelectArrayIterator或参见参考源.

但是,类本身实现了IEnumerable ,它允许将它分配给您的变量.您所犯的错误是将可分配类型(IEnumerable )与实现类型(WhereSelectArrayInterator)混淆.当你只有一个where语句时,只有一个泛型类型,因为它不会将类型从源转换为结果.

在这种情况下,打印类型的名称将给你答案.

推荐阅读
mylvfamily
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有