Expression Tree Introduction - 02

上一篇介绍了表达式树的一些基本用法,这里介绍下包含更复杂逻辑的表达式树。

1.判断逻辑的表达式树

LabelTarget labelBreak = Expression.Label();
ParameterExpression loopIndex = Expression.Parameter(typeof(int), "index");

BlockExpression block = Expression.Block(
            new[] { loopIndex },
                // 初始化loopIndex =1
                Expression.Assign(loopIndex, Expression.Constant(1)),
                Expression.Loop(
                    Expression.IfThenElse(
                // if 的判断逻辑
                        Expression.LessThanOrEqual(loopIndex, Expression.Constant(10)),
                // 判断逻辑通过的代码
                        Expression.Block(
                            Expression.Call(
                                null,
                                typeof(Console).GetMethod("WriteLine", new Type[] { typeof(string) }),
                                Expression.Constant("Hello")),
                            Expression.PostIncrementAssign(loopIndex)),
                // 判断不通过的代码
                        Expression.Break(labelBreak)
                        ), labelBreak));

            // 将我们上面的代码块表达式
Expression<Action> lambdaExpression = Expression.Lambda<Action>(block);
lambdaExpression.Compile().Invoke();
这个表达式阅读起来有点费劲,不过仔细读一下还是比较好理解的。

2.类型判断的表达式树

TypeBinaryExpression typeBinaryExpression =
                Expression.TypeIs(
                    //Expression.Constant(3),
                    Expression.Constant("Hello"),
                    typeof(int));

Console.WriteLine(typeBinaryExpression.ToString());
BlockExpression block = Expression.Block(typeBinaryExpression);

Expression<Func<bool>> e = Expression.Lambda<Func<bool>>(block);
Console.WriteLine(e.Compile().DynamicInvoke());
这个表达式树是构建了一个类型判断的表达式,我们首先打印出表达式,然后我们调用表达式。





  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值