我想生成一个与此类似的方法:
void Add(ref MyStruct a, MyStruct b)
{
a.Field1 += b.Field1;
// a.Field2 += b.Field2; // and so on
}
为此我宣布了我的自定义委托:
public delegate void Add<T>(ref T a, T b) where T : struct;
并编写我的表达式构建器:
public static Expression<Add<T>> BuildExpression<T>() where T : struct
{
var t = typeof(T);
var a = Expression.Parameter(t.MakeByRefType(), "a");
var b = Expression.Parameter(t, "b");
return Expression.Lambda<Add<T>>(
Expression.Block(
t.GetFields().Select(f =>
Expression.AddAssign(Expression.Field(a, f), Expression.Field(b, f)))),
a, b
);
}
我已添加MyStruct
一个字段Field1
来测试它。当我检查表达式的DebugView
时,它看起来与预期结果非常相似:
.Lambda #Lambda1<Program+Add`1[Program+MyStruct]>(
Program+MyStruct& $a,
Program+MyStruct $b) {
.Block() {
$a.Field1 += $b.Field1
}
}
然而它不会修改第一个参数。请参阅demo
那么我在BuildExpression
中做错了什么?