![](/img/trans.png)
[英]Using ExpressionVisitor to modify expression for automatic translations
[英]Expression Tree: Modify operand using ExpressionVisitor
我在玩C#中的Expression树,想修改一个表达式。
我使用了此示例,但是在该示例中,它们重用了左节点和右节点。 我将如何修改任一节点?
我得到以下代码:
[TestMethod]
public void ExpressionDemo_ModifiesExpression()
{
var demo = new ExpressionDemo();
var expression = demo.ModifyAddition((Expression<Func<int, int>>)(x => x + 1));
}
我使用一个简单的+ 1加法函数来调用ModifyAddition。 我想将正确的操作数(1)修改为其他整数。
public class ExpressionDemo : ExpressionVisitor
{
public Expression<Func<int, int>> ModifyAddition(Expression func)
{
return (Expression<Func<int, int>>) Visit(func);
}
protected override Expression VisitBinary(BinaryExpression node)
{
if (node.NodeType == ExpressionType.Add)
{
Expression left = node.Left;
Expression right = ???
return Expression.MakeBinary(ExpressionType.Add, left, right);
}
return base.VisitBinary(node);
}
}
我对如何构造正确的右操作数感到困惑,因此我可以返回一个新的BinaryExpression。
您是否只想将x + y
转换为x + 1
? 如果是这样,我怀疑您只是想要:
Expression right = Expression.Constant(1);
(当然,您应该验证加法类型是否为整数。)
如果这不是您要尝试的操作,请更加具体。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.