Expression Trees

[索引页]

Expression trees语言级别的代码呈现数据形式.这个数据被存储在一个数形结构中.在Expression trees中每一个节点呈现一个表达式,如一个方法调用或二元运算符.

下面图显示是一个Expression的事例和它呈现的一个Expression trees的形式.Expression不同部分是匹配相应的Expression trees子节点的有颜色的代码.




还有Expression trees子节点的类型不同.

下面的事例代码示范怎样表达树呈现lambda表达式 num => num < 5 (C#) or Function(num) num < 5 (Visual Basic)被分解为几部分.

//  Add the following using directive to your code file:
//  using System.Linq.Expressions;

//  Create an expression tree.
Expression < Func < int bool >>  exprTree  =  num  =>  num  <   5 ;

//  Decompose the expression tree.
ParameterExpression param  =  (ParameterExpression)exprTree.Parameters[ 0 ];
BinaryExpression operation 
=  (BinaryExpression)exprTree.Body;
ParameterExpression left 
=  (ParameterExpression)operation.Left;
ConstantExpression right 
=  (ConstantExpression)operation.Right;

Console.WriteLine(
" Decomposed expression: {0} => {1} {2} {3} " ,
                  param.Name, left.Name, operation.NodeType, right.Value);

/**/ /*  This code produces the following output:

    Decomposed expression: num => num LessThan 5
*/



Building Expression Trees


在System.Linq.Expressions 命名空间里提供一个API来手动构建expression trees.The Expression类包括创建表达树指定子节点的类型的static factory methods.如一个ParameterExpression,它是呈现一个表达式参数名,或一个MethodCallExpression,而这一个是呈现一个调用方法.ParameterExpression, MethodCallExpression,和其他的详细的指定表达树类型的expression定义在System.Linq.Expressions命名空间中.这些类型都派生于抽象类型Expression.

编译器还能自动为你构建一个expression tree.一个编译器产生表达式树是始终来源于一个子节点的Expression(TDelegate)类型;就是说,它的根节点的子节点呈现lambda表达式.

下面代码事例是以两个方式创建一个呈现ambda expression num => num < 5 (C#) or Function(num) num < 5 (Visual Basic)的表达式树.

//  Add the following using directive to your code file:
//  using System.Linq.Expressions;

//  Manually build the expression tree for
//  the lambda expression num => num < 5.
ParameterExpression numParam  =  Expression.Parameter( typeof ( int ),  " num " );
ConstantExpression five 
=  Expression.Constant( 5 typeof ( int ));
BinaryExpression numLessThanFive 
=  Expression.LessThan(numParam, five);
Expression
< Func < int bool >>  lambda1  =
    Expression.Lambda
< Func < int bool >> (
        numLessThanFive,
        
new  ParameterExpression[]  { numParam } );

//  Let the compiler generate the expression tree for
//  the lambda expression num => num < 5.
Expression < Func < int bool >>  lambda2  =  num  =>  num  <   5 ;



Immutability of Expression Trees


Expression trees是不可变化的.这个意思是如果你要修改一个表达树,你必须copey和修改现有的表达式树构建一个新的表达式树.你能使用一个表达式树访问者来跨越到其他表达式树上.


 Lambda Expressions


当一个lambda expression 被分配一个Expression(TDelegate)类型的变量,这个编译器就会发布一个呈现lambda表达式的表达式树.例如一些标准查询操作符(standard query operator methods)方法被定义在Queryable类中且已有的参数类型为Expression(TDelegate).你能通过在lambda expression中调用这些方法并且编译器将产生一个表达式树.

而这里的Expression(TDelegate)类型提供一个Compile方法,这个方法是将呈现表达式树的代码编译成为一个可执行的委托.这个可执行的代码是相当于将代码按照已有lambda expression分配的最初委托类型来生成.

注意:

仅仅这些expression trees呈现的功能,也就是Expression(TDelegate)和它父类型LambdaExpression,能被编译成执行代码,你必须首先在Lambda Expression 的子节点约束他们执行在其他的表达树的类型.你能按照调用Lambda方法和通过表达式树的参数来获得这样的Lambda Expression.

原文地址

------------- worksguo

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值