![](/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.