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'方法
这似乎可以工作:
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
,但这是一个单独的问题。