lambda表达式树
生活随笔
收集整理的這篇文章主要介紹了
lambda表达式树
小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.
一、定義:
表達(dá)式樹又稱為表達(dá)式目錄樹,以數(shù)據(jù)形式表示語言級代碼。所有的數(shù)據(jù)都存儲在樹結(jié)構(gòu)中,每個結(jié)點(diǎn)表示一個表達(dá)式(Expression)。
二、要點(diǎn):
–Lambda表達(dá)式的參數(shù)類型可以忽略,因?yàn)榭梢愿鶕?jù)使用的上下文進(jìn)行推斷。 –Lambda表達(dá)式的主體(body)可以是表達(dá)式,也可以是語句塊。 –Lambda表達(dá)式傳入的實(shí)參將參與類型推斷,以及方法重載辨析。 –Lambda表達(dá)式和表達(dá)式體可以被轉(zhuǎn)換為表達(dá)式樹。表達(dá)式樹允許lambda表達(dá)式能夠代表數(shù)據(jù)結(jié)構(gòu)替代表示為執(zhí)行代碼。
//簡單應(yīng)用Expression<Func<int, int, int>> lambda = (x, y) => x + y;Func<int, int, int> fun = lambda.Compile();//表達(dá)式拼接ParameterExpression p1 = Expression.Parameter(typeof(int), "i");ParameterExpression p2 = Expression.Parameter(typeof(int), "j");BinaryExpression r1 = Expression.Multiply(p1, p2);ParameterExpression p3 = Expression.Parameter(typeof(int), "i");ParameterExpression p4 = Expression.Parameter(typeof(int), "j");BinaryExpression r2 = Expression.Multiply(p3, p4);BinaryExpression result = Expression.Add(r1, r2);//終極運(yùn)算Expression<Func<int, int, int, int, int>> lambda = Expression.Lambda<Func<int, int, int, int, int>>(result, p1, p2, p3, p4);Func<int, int, int, int, int> fun = lambda.Compile();Console.WriteLine(fun(1, 2, 3, 4));Console.ReadLine();
轉(zhuǎn)載于:https://www.cnblogs.com/sjqq/p/8006609.html
總結(jié)
以上是生活随笔為你收集整理的lambda表达式树的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: “天性有时迁”下一句是什么
- 下一篇: Tomcat 调优及 JVM 参数优化