




版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)
文檔簡介
第C#五類運算符使用表達式樹進行操作在C#中,算術(shù)運算符,有以下類型
算術(shù)運算符關(guān)系運算符邏輯運算符位運算符賦值運算符其他運算符
這些運算符根據(jù)參數(shù)的多少,可以分作一元運算符、二元運算符、三元運算符。本文將圍繞這些運算符,演示如何使用表達式樹進行操作。
對于一元運算符和二元運算符的Expression的子類型如下:
UnaryExpression;//一元運算表達式
BinaryExpression;//二元運算表達式
一,算術(shù)運算符
運算符描述+把兩個操作數(shù)相加-從第一個操作數(shù)中減去第二個操作數(shù)*把兩個操作數(shù)相乘/分子除以分母%取模運算符,整除后的余數(shù)++自增運算符,整數(shù)值增加1--自減運算符,整數(shù)值減少1
+與Add()
正常代碼
inta;
intb;
a=100;
b=200;
varab=a+b;
Console.WriteLine(ab);
使用表達式樹構(gòu)建
ParameterExpressiona=Expression.Parameter(typeof(int),"a");
ParameterExpressionb=Expression.Parameter(typeof(int),"b");
//ab=a+b
BinaryExpressionab=Expression.Add(a,b);
//打印a+b的值
MethodCallExpressionmethod=Expression.Call(null,typeof(Console).GetMethod("WriteLine",newType[]{typeof(int)}),ab);
ExpressionActionint,intlambda=Expression.LambdaActionint,int(method,a,b);
lambda.Compile()(100,200);
Console.ReadKey();
如果想復雜一些,使用塊來執(zhí)行:
ParameterExpressiona=Expression.Parameter(typeof(int),"a");
ParameterExpressionb=Expression.Parameter(typeof(int),"b");
//別忘記了賦值
BinaryExpressionaa=Expression.Assign(a,Expression.Constant(100,typeof(int)));
BinaryExpressionbb=Expression.Assign(b,Expression.Constant(200,typeof(int)));
//ab=a+b
BinaryExpressionab=Expression.Add(a,b);
//打印a+b的值
MethodCallExpressionmethod=Expression.Call(null,typeof(Console).GetMethod("WriteLine",newType[]{typeof(int)}),ab);
//以塊的形式執(zhí)行代碼,相當于{}
//不需要糾結(jié)這里,后面會有詳細說明,重點是上面
varcall=Expression.Block(newParameterExpression[]{a,b},aa,bb,method);
ExpressionActionlambda=Expression.LambdaAction(call);
lambda.Compile()();
上面兩個示例,是使用表達式樹計算結(jié)果,然后還是使用表達式樹打印結(jié)果。
前者依賴外界傳入?yún)?shù)值,賦予a、b,后者則全部使用表達式樹賦值和運算。
那么,如何通過表達式樹執(zhí)行運算,獲取執(zhí)行結(jié)果呢?
ParameterExpressiona=Expression.Parameter(typeof(int),"a");
ParameterExpressionb=Expression.Parameter(typeof(int),"b");
//ab=a+b
BinaryExpressionab=Expression.Add(a,b);
ExpressionFuncint,int,intlambda=Expression.LambdaFuncint,int,int(ab,a,b);
intresult=lambda.Compile()(100,200);
Console.WriteLine(result);
Console.ReadKey();
這些區(qū)別在于如何編寫Expression.Lambda()。
另外,使用AddChecked()可以檢查操作溢出。
-與Subtract()
與加法一致,此處不再贅述,SubtractChecked()可以檢查溢出。
a-b,結(jié)果是100。
ParameterExpressiona=Expression.Parameter(typeof(int),"a");
ParameterExpressionb=Expression.Parameter(typeof(int),"b");
//ab=a-b
BinaryExpressionab=Expression.Subtract(a,b);
ExpressionFuncint,int,intlambda=Expression.LambdaFuncint,int,int(ab,a,b);
intresult=lambda.Compile()(200,100);
Console.WriteLine(result);
乘除、取模
乘法
//ab=a*b
BinaryExpressionab=Expression.Multiply(a,b);
//ab=20000
除法
//ab=a/b
BinaryExpressionab=Expression.Divide(a,b);
//ab=2
取模(%)
ParameterExpressiona=Expression.Parameter(typeof(int),"a");
ParameterExpressionb=Expression.Parameter(typeof(int),"b");
//ab=a%b
BinaryExpressionab=Expression.Modulo(a,b);
ExpressionFuncint,int,intlambda=Expression.LambdaFuncint,int,int(ab,a,b);
intresult=lambda.Compile()(200,150);
//ab=50
Console.WriteLine(result);
Console.ReadKey();
自增自減有兩種模型,一種是x++或x--,另一種是++x或--x。
他們都是屬于UnaryExpression類型。
算術(shù)運算符表達式樹說明x++Expression.PostIncrementAssign()后置x--Expression.PostDecrementAssign()后置++xExpression.PreIncrementAssign()前置--xExpression.PreDecrementAssign()前置
巧記:Post后置,Pre前置;Increment是加,Decrement是減;Assign與賦值有關(guān)(后面會說到);
x++與x--的使用
inta=10;
intb=10;
a++;
b--;
Console.WriteLine(a);
Console.WriteLine(b);
//inta,b;
ParameterExpressiona=Expression.Parameter(typeof(int),"a");
ParameterExpressionb=Expression.Parameter(typeof(int),"b");
//a=10,b=10;
BinaryExpressionsetA=Expression.Assign(a,Expression.Constant(10));
BinaryExpressionsetB=Expression.Assign(b,Expression.Constant(10));
//a++
UnaryExpressionaa=Expression.PostIncrementAssign(a);
//b--
UnaryExpressionbb=Expression.PostDecrementAssign(b);
//Console.WriteLine(a);
//Console.WriteLine(b);
MethodCallExpressioncallA=Expression.Call(null,typeof(Console).GetMethod("WriteLine",newType[]{typeof(int)}),a);
MethodCallExpressioncallB=Expression.Call(null,typeof(Console).GetMethod("WriteLine",newType[]{typeof(int)}),b);
BlockExpressionblock=Expression.Block(
newParameterExpression[]{a,b},
setA,
setB,
callA,
callB
ExpressionActionlambda=Expression.LambdaAction(block);
lambda.Compile()();
Console.ReadKey();
如果想把參數(shù)從外面?zhèn)魅耄O置a,b
//inta,b;
ParameterExpressiona=Expression.Variable(typeof(int),"a");
ParameterExpressionb=Expression.Variable(typeof(int),"b");
//a++
UnaryExpressionaa=Expression.PostIncrementAssign(a);
//b--
UnaryExpressionbb=Expression.PostDecrementAssign(b);
//Console.WriteLine(a);
//Console.WriteLine(b);
MethodCallExpressioncallA=Expression.Call(null,typeof(Console).GetMethod("WriteLine",newType[]{typeof(int)}),a);
MethodCallExpressioncallB=Expression.Call(null,typeof(Console).GetMethod("WriteLine",newType[]{typeof(int)}),b);
BlockExpressionblock=Expression.Block(
callA,
callB
ExpressionActionint,intlambda=Expression.LambdaActionint,int(block,a,b);
lambda.Compile()(10,10);
Console.ReadKey();
生成的表達式樹如下
.Lambda#Lambda1System.Action`2[System.Int32,System.Int32](
System.Int32$a,
System.Int32$b){
.Block(){
$a++;
$b--;
.CallSystem.Console.WriteLine($a);
.CallSystem.Console.WriteLine($b)
}
為了理解一下Expression.Block(),可以在這里學習一下(后面會說到Block())。
//inta,b;
ParameterExpressiona=Expression.Parameter(typeof(int),"a");
ParameterExpressionb=Expression.Parameter(typeof(int),"b");
ParameterExpressionc=Expression.Variable(typeof(int),"c");
BinaryExpressionSetA=Expression.Assign(a,c);
BinaryExpressionSetB=Expression.Assign(b,c);
//a++
UnaryExpressionaa=Expression.PostIncrementAssign(a);
//b--
UnaryExpressionbb=Expression.PostDecrementAssign(b);
//Console.WriteLine(a);
//Console.WriteLine(b);
MethodCallExpressioncallA=Expression.Call(null,typeof(Console).GetMethod("WriteLine",newType[]{typeof(int)}),a);
MethodCallExpressioncallB=Expression.Call(null,typeof(Console).GetMethod("WriteLine",newType[]{typeof(int)}),b);
BlockExpressionblock=Expression.Block(
newParameterExpression[]{a,b},
SetA,
SetB,
callA,
callB
ExpressionActionintlambda=Expression.LambdaActionint(block,c);
lambda.Compile()(10);
Console.ReadKey();
為什么這里要多加一個c呢?我們來看看生成的表達式樹
.Lambda#Lambda1System.Action`1[System.Int32](System.Int32$c){
.Block(
System.Int32$a,
System.Int32$b){
$a=$c;
$b=$c;
$a++;
$b--;
.CallSystem.Console.WriteLine($a);
.CallSystem.Console.WriteLine($b)
}
觀察一下下面代碼生成的表達式樹
//inta,b;
ParameterExpressiona=Expression.Parameter(typeof(int),"a");
ParameterExpressionb=Expression.Parameter(typeof(int),"b");
//a++
UnaryExpressionaa=Expression.PostIncrementAssign(a);
//b--
UnaryExpressionbb=Expression.PostDecrementAssign(b);
//Console.WriteLine(a);
//Console.WriteLine(b);
MethodCallExpressioncallA=Expression.Call(null,typeof(Console).GetMethod("WriteLine",newType[]{typeof(int)}),a);
MethodCallExpressioncallB=Expression.Call(null,typeof(Console).GetMethod("WriteLine",newType[]{typeof(int)}),b);
BlockExpressionblock=Expression.Block(
newParameterExpression[]{a,b},
callA,
callB
ExpressionActionint,intlambda=E
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責。
- 6. 下載文件中如有侵權(quán)或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 高中語文聽課心得體會模版
- 英語十六時態(tài)表格完整總結(jié)模版
- 《社區(qū)兒童活動規(guī)劃》課件
- 醫(yī)師資格考試2025年臨床執(zhí)業(yè)助理醫(yī)師資格考試考點總結(jié)模版
- 先進生產(chǎn)力是新質(zhì)生產(chǎn)力
- 冬季疾病防治培訓
- C++繼承和動態(tài)內(nèi)存分配
- 設定目標管理團隊總結(jié)
- 《卓越時間管理策略》課件
- 2025大學生兼職工作:簽訂實習合同還是勞務合同
- 人教版(2024)七年級下冊Unit 3 Keep fit 素養(yǎng)檢測(含解析)
- 2025年四川省成都市成華區(qū)中考二診英語試題(含筆試答案無聽力音頻及原文)
- 綏化綏化市2025年度“市委書記進校園”事業(yè)單位引才287人筆試歷年參考題庫附帶答案詳解
- 歷史七年級歷史下冊期中復習知識點梳理課件 2024-2025學年七年級歷史下冊(統(tǒng)編版2024)
- 醫(yī)院檢驗科實驗室生物安全程序文件SOP
- 封條模板A4直接打印版
- 雙減背景下的作業(yè)設計與實施優(yōu)秀案例PPT
- 基于PLC的數(shù)控車床電氣控制系統(tǒng)設計畢業(yè)論文_(2)[1]
- 古典概型 教學設計
- 鋼管截面積、強度、撓度、慣性矩計算公式
- 施工現(xiàn)場平面布置和臨時設施、臨時道路布置
評論
0/150
提交評論