繁体   English   中英

表达式树:使用ExpressionVisitor修改操作数

[英]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.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM