您好,登錄后才能下訂單哦!
c# 中怎么實現表達式樹實驗,針對這個問題,這篇文章詳細介紹了相對應的分析和解答,希望可以幫助更多想解決這個問題的小伙伴找到更簡單易行的方法。
Func<int, int, int> myfunc = (a, b) => a + b;
Expression<Func<int, int, int>> expression = (a, b) => a * b;
Console.WriteLine(myfunc(3, 4));
//Console.WriteLine(expression(5, 6));//expression是變量,但此處當作方法
//上面分別表示Func委托和表達式樹,看上去很相似。對于委托我們能控制執行,但內部代碼在程序運行中是無法得知的,而表達式樹剛好相反,表達式樹是一種數據結構,可以獲取內部細節。
//上面xpression中是使用Lambda為表達式樹賦值,還可以:
ParameterExpression parameterExpressionA = Expression.Parameter(typeof(int),"a");
//expression.Parameter(typeof(int), "a");//什么意思???
//public static ParameterExpression Expression.Parameter(Type pyte,string name); //創建一個Expresions.ParameterExpression節點,該節點可用于標識樹中的參數或變量
//返回值Expressions.ParameterExpression,其Expressions.Expression.NodeType屬性等于Expressions.ExpressionType.Parameter,并且其Expressions.Expression.Type和Expressions.ParameterExpression.Name屬性設置為指定值
ParameterExpression parameterExpressionB = Expression.Parameter(typeof(int), "b");
BinaryExpression binaryExpression = Expression.Add(parameterExpressionA, parameterExpressionB);
//BinaryExpression包含二元運算符的表達式
//public sealed class Expression<TDelegate>:LambdaExpression
//以目錄樹的形式將強類型 lambda表達式 表示為數據結構
//其中二個函數很有意思:
//public TDelegate Compile();將表達式樹描述的lambda表達式編譯為可執行代碼并生成表示該lambda表達式的委托
//public TDelegate Compile(DebugInfoGernerator debugInfoGenerator)帶調試信息生成器
//Expression<Func<int, int, int>> expressionD = Expression.Lambda(binaryExpression, parameterExpressionA, parameterExpressionB); //如果沒有泛型指定類型則顯示轉換錯誤
Expression<Func<int, int, int>> expressionD = Expression.Lambda<Func<int, int, int>>(binaryExpression, parameterExpressionA, parameterExpressionB);
//也就是說最開始的Expression<Func<int,int,int>> expression = (a,b) => a + b;其實就是上面的expressionD
//Expression類是一個抽象類,表示表達式目錄樹節點的類派生自該基類,它還包含用來創建各種節點類型的靜態工廠方法。
//Expression類有很多子類,比如LambdaExpression,BinaryExpression,ParameterExpression,ConstantExpression,ConditionExpression,GotoExpression,LabelExpression等
//其中LambdaExpression類中:
//public Expression Body{get;}獲取Lambda表達式的主體
//public string name{get;}獲取Lambda表達式的名稱
//public overrid sealed ExpressionType NodeType{get;}返回此Expression的節點類型 注意這種語法格式:因為在父類Expression中public virtual ExpressionType NodeType{get;}
//也就是說在C#中父類virtual一個方法或屬性方法之后,在子類中對這個方法或屬性方法可以override,再如果加上sealed則表示不允許修改了
//public ReadOnlyCollection<ParameterExpression> Parameters{get;}獲取Lambda表達式的參數
//pulbic Type ReturnType{get;} 返回值類型
//pubilc override sealed Type[get;}獲取此Expression所表示的表達式的靜態類型
Console.WriteLine(expression.Body.ToString()); //(a * b)
Console.WriteLine(expression.NodeType.ToString());//Lambda
Console.WriteLine(parameterExpressionA.NodeType.ToString() + "----" + parameterExpressionA.Type.BaseType.ToString());//Parameter----System.ValueType
//除了System.ValueType,是不是還有引用類型??
//Expression<Func<int,int,RefClas>> rcexp = (a,b)=>{return new RefClas(a,b);}//無法將具有語句體的Lambda表達式轉換為Lambda表達式樹
//Expression<Func<int,int,RefClas>> rcexp = 感覺是不是要定義一個int int到RefClas對象的操作才能變成Lambad表達式樹???????
//比如ExpressionType等于ExpressionType.Convert的表達式操作 Convert強制轉換或轉換運算,如(SampleType)obj;對于數值轉換,超范圍轉換也不會引發異常。具體如何寫代碼???
//Lambda方法和通過API創建方法,共二種創建表達式樹
//API方法:
ParameterExpression numParameterExpression = Expression.Parameter(typeof(int), "num");
ConstantExpression five = Expression.Constant(5, typeof(int));
BinaryExpression numLessThanFive = Expression.LessThan(numParameterExpression, five);
Expression<Func<int, bool>> lambda = Expression.Lambda<Func<int, bool>>(numLessThanFive, numParameterExpression);
Console.WriteLine("lambda的內容:{0}", lambda.ToString());//lambda的內容:num => (num < 5)
//表達式的編譯
var func = lambda.Compile();
Console.WriteLine("lambda的運行結果=" + func(6));
關于c# 中怎么實現表達式樹實驗問題的解答就分享到這里了,希望以上內容可以對大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關注億速云行業資訊頻道了解更多相關知識。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。