zoukankan      html  css  js  c++  java
  • LINQ表达式树4

    执行表达式目录树

    前面已经可以构造出一个表达式目录树了,现在看看如何去执行表达式目录树。我们需要调用Compile方法来创建一个可执行委托,并且调用该委托,如下面的代码:

    static void Main(string[] args)
    {
        ParameterExpression paraLeft = Expression.Parameter(typeof(int), "a");
        ParameterExpression paraRight = Expression.Parameter(typeof(int), "b");
        BinaryExpression binaryLeft = Expression.Multiply(paraLeft, paraRight);
        ConstantExpression conRight = Expression.Constant(2, typeof(int));
        BinaryExpression binaryBody = Expression.Add(binaryLeft, conRight);
        Expression<Func<int, int, int>> lambda = 
            Expression.Lambda<Func<int, int, int>>(binaryBody, paraLeft, paraRight);
        Func<int, int, int> myLambda = lambda.Compile();
        int result = myLambda(2, 3);
        Console.WriteLine("result:" + result.ToString());
        Console.Read();
    }

    运行后输出的结果:

    TerryLee_0159

    这里我们只要简单的调用Compile方法就可以了,事实上在.NET Framework中是调用了一个名为ExpressionCompiler的内部类来做表达式目录树的执行(注意此处的Compiler不等同于编译器的编译)。另外,只能执行表示Lambda表达式的表达式目录树,即LambdaExpression或者Expression<TDelegate>类型。如果表达式目录树不是表示Lambda表达式,需要调用Lambda方法创建一个新的表达式。如下面的代码:

    static void Main(string[] args)
    {
        BinaryExpression body = Expression.Add(
            Expression.Constant(2),
            Expression.Constant(3));
        Expression<Func<int>> expression = 
            Expression.Lambda<Func<int>>(body, null);
        Func<int> lambda = expression.Compile();
        Console.WriteLine(lambda());
    }
  • 相关阅读:
    poj 2337 欧拉回路输出最小字典序路径 ***
    hdu 4831
    hdu 4832 dp ***
    hdu 4833 离散化+dp ****
    hdu 4006 优先队列 2011大连赛区网络赛F **
    hdu 4005 双联通 2011大连赛区网络赛E *****
    hdu 4004 二分 2011大连赛区网络赛D
    hdu 4003 树形dp+分组背包 2011大连赛区网络赛C
    hdu 4002 欧拉函数 2011大连赛区网络赛B
    跨域经验总结
  • 原文地址:https://www.cnblogs.com/meilibao/p/2681340.html
Copyright © 2011-2022 走看看