How to call extension method “ElementAt”of List with reflection?

前端 未结 4 1947
清歌不尽
清歌不尽 2020-12-19 07:00

I have problem that after creating object \"oListType01\" of type List < MyClass01 > and after assigning it to the another objet \"oObjectType \" of type \"object\" I ca

相关标签:
4条回答
  • 2020-12-19 07:17

    This is really similar to your other question, but in this case, the static ElementAt method is actually requiring two parameters. Try this:

    object oSingleObject = mInfo.Invoke(null, new object[] { oObjectType, 1 });

    0 讨论(0)
  • 2020-12-19 07:24

    If we can safely assume that:

    • oObjectType is a IEnumerable of some T

    then here's the code to extract the items from it.

    Note that I seriously wonder if this is the right way to go about this, but you haven't given us enough information to help you figure out if there's a better way, so all we're left with is just answering the question as asked.

    using System;
    using System.Collections.Generic;
    using System.Linq;
    using System.Reflection;
    using System.Diagnostics;
    
    namespace ConsoleApplication2
    {
        class MyClass01
        {
            public String _ID;
    
            public override string ToString()
            {
                return _ID;
            }
        }
    
        class Program
        {
            static void Main(string[] args)
            {
                MyClass01 oMy1 = new MyClass01();
                oMy1._ID = "1";
    
                MyClass01 oMy2 = new MyClass01();
                oMy2._ID = "3";
    
                IList<MyClass01> oListType01 = new List<MyClass01>();
    
                oListType01.Add(oMy1);
                oListType01.Add(oMy2);
    
                object oObjectType = new object();
    
                oObjectType = oListType01;
    
                Test(oObjectType);
    
                Console.In.ReadLine();
            }
    
            private static void Test(object oObjectType)
            {
                Type tObject = oObjectType.GetType();
                Debug.Assert(tObject.IsGenericType);
                Debug.Assert(tObject.GetGenericArguments().Length == 1);
                Type t = tObject.GetGenericArguments()[0];
    
                Type tIEnumerable = typeof(IEnumerable<>).MakeGenericType(t);
                Debug.Assert(tIEnumerable.IsAssignableFrom(tObject));
    
                MethodInfo mElementAt =
                    typeof(Enumerable)
                    .GetMethod("ElementAt")
                    .MakeGenericMethod(t);
    
                Console.Out.WriteLine("o[0] = " +
                    mElementAt.Invoke(null, new Object[] { oObjectType, 0 }));
                Console.Out.WriteLine("o[1] = " +
                    mElementAt.Invoke(null, new Object[] { oObjectType, 1 }));
            }
        }
    }
    
    0 讨论(0)
  • 2020-12-19 07:38

    The ElementAt extension method is probably on IEnumerable<T> and so when you treat your list like an object, the extension method won't be available unless you cast it. Either ((List<MyClass01>)oObjectType).ElementAt() or (oObjectType as List<MyClass01>).ElementAt().

    I have to ask, though, with all due respect why you'd ever want to do this in the first place? It strikes me that there's something wrong here that could be done a little cleaner using interfaces.

    0 讨论(0)
  • 2020-12-19 07:40

    I will assume you have a valid reason to be doing this but it seems a little wrong. That said here is some code that will accomplish what you are trying to do.

    MethodInfo mInfo = typeof(System.Linq.Enumerable).GetMethod("ElementAt").MakeGenericMethod(typeof(MyClass01));
    object oSingleObject = mInfo.Invoke(oObjectType, new object[] { oObjectType, 1 });
    

    When I run this code I get the second element in the List.

    0 讨论(0)
提交回复
热议问题