calling Expression.Call

本文关键字:Call Expression calling | 更新日期: 2023-09-27 18:07:04

我有:

class X<t1>
{
   class Y<t2>
   {
      public Y<t2> Skip(int count)
      {
          var mi = (MethodInfo)MethodBase.GetCurrentMethod();
          var f = Expression.Call(null, mi,Expression.Constant(count));
          var x = this.Provider.CreateQuery(f);
          return something_else;
      }
   }
}

我得到Y ' 1 Skip(Int32)包含泛型参数。

不能使方法泛型,所以我可以调用method。MakeGenericType

关于如何创建表达式的任何想法。电话吗?

我也试过:

var f = Expression.Call(typeof(Y<>), "Skip", new Type[] { gt }, Expression.Constant(count));

这次我得到:

类型'X 1+Y 1[t1,t2]'上不存在'Skip'方法

calling Expression.Call

这似乎可以工作:

var f = Expression.Call(
     Expression.Constant(this), 
     "Skip", 
     Type.EmptyTypes, 
     Expression.Constant(count));

顺便说一下,Type.EmptyTypes等价于new Type[0]

如文档所述,GetCurrentMethod不填充拥有当前方法的类型的泛型参数。

可以选择:

MethodInfo mi = typeof(X<t1>.Y<t2>).GetMethod("Skip");
Expression f = Expression.Call(null, mi, Expression.Constant(count))

同样,第一个参数不应该是null,但这是一个单独的问题。