bl双性强迫侵犯h_国产在线观看人成激情视频_蜜芽188_被诱拐的少孩全彩啪啪漫画

C#表達(dá)式樹的簡單介紹

這篇文章主要為大家詳細(xì)介紹了C#中的表達(dá)式樹,圖文詳解容易學(xué)習(xí),配合代碼閱讀理解效果更佳,非常適合初學(xué)者入門,感興趣的小伙伴們可以參考一下。

創(chuàng)新互聯(lián)專注于平山企業(yè)網(wǎng)站建設(shè),成都響應(yīng)式網(wǎng)站建設(shè),購物商城網(wǎng)站建設(shè)。平山網(wǎng)站建設(shè)公司,為平山等地區(qū)提供建站服務(wù)。全流程按需網(wǎng)站制作,專業(yè)設(shè)計(jì),全程項(xiàng)目跟蹤,創(chuàng)新互聯(lián)專業(yè)和態(tài)度為您提供的服務(wù)

表達(dá)式樹可以說是Linq的核心之一,為什么是Linq的核心之一呢?因?yàn)楸磉_(dá)式樹使得c#不再是僅僅能編譯成IL,我們可以通過c#生成一個(gè)表達(dá)式樹,將結(jié)果作為一個(gè)中間格式,在將其轉(zhuǎn)換成目標(biāo)平臺上的本機(jī)語言。比如SQL。我們常用的Linq to sql就是這樣生成SQL的。

表達(dá)式樹是.NET 3.5之后引入的,它是一個(gè)強(qiáng)大靈活的工具(比如用在LINQ中構(gòu)造動態(tài)查詢)。

先來看看Expression類的API接口:

namespace System.Linq.Expressions
{
    //
    // 摘要:
    //     以表達(dá)式目錄樹的形式將強(qiáng)類型 lambda 表達(dá)式表示為數(shù)據(jù)結(jié)構(gòu)。此類不能被繼承。
    //
    // 類型參數(shù):
    //   TDelegate:
    //     System.Linq.Expressions.Expression`1 表示的委托的類型。
    public sealed class Expression<TDelegate> : LambdaExpression
    {
        //
        // 摘要:
        //     將表達(dá)式樹描述的 lambda 表達(dá)式編譯為可執(zhí)行代碼,并生成表示該 lambda 表達(dá)式的委托。
        //
        // 返回結(jié)果:
        //     一個(gè) TDelegate 類型的委托,它表示由 System.Linq.Expressions.Expression`1 描述的已編譯的 lambda 表達(dá)式。
        public TDelegate Compile();
        //
        // 摘要:
        //     生成表示 lambda 表達(dá)式的委托。
        //
        // 參數(shù):
        //   debugInfoGenerator:
        //     編譯器用于標(biāo)記序列點(diǎn)并批注局部變量的調(diào)試信息生成器。
        //
        // 返回結(jié)果:
        //     包含 lambda 的已編譯版本的委托。
        public TDelegate Compile(DebugInfoGenerator debugInfoGenerator);
        //
        // 摘要:
        //     創(chuàng)建一個(gè)與此表達(dá)式類似的新表達(dá)式,但使用所提供的子級。如果所有子級都相同,則將返回此表達(dá)式。
        //
        // 參數(shù):
        //   body:
        //     結(jié)果的 System.Linq.Expressions.LambdaExpression.Body 屬性。
        //
        //   parameters:
        //     結(jié)果的 System.Linq.Expressions.LambdaExpression.Parameters 屬性。
        //
        // 返回結(jié)果:
        //     此表達(dá)式(如果未更改任何子級),或帶有更新的子級的表達(dá)式。
        public Expression<TDelegate> Update(Expression body, IEnumerable<ParameterExpression> parameters);
        protected internal override Expression Accept(ExpressionVisitor visitor);
    }
}

表達(dá)式樹的語法如下:

Expression<Func<type,returnType>> = (param) => lamdaexpresion;

例如:

Expression<Func<int, int, int>> expr = (x, y) => x+y;

我們運(yùn)行以上代碼,并在VS調(diào)試模似下查看這個(gè)表達(dá)式樹:

C#表達(dá)式樹的簡單介紹

可以看到表達(dá)式樹主要由下面四部分組成:

1、Body 主體部分

2、Parameters 參數(shù)部分

3、NodeType 節(jié)點(diǎn)類型

4、Lambda表達(dá)式類型

在上述代碼中,主體即為:x+y,參數(shù)為(x,y),NodeType為Lambda表達(dá)式,返回值為int

主體部分可以是表達(dá)式,但是不能包含語句。例如:我定義一個(gè)委托,Lambda表達(dá)式可以這樣寫

Func<int, int, int> func = (x, y) => x + y;

也可以這樣寫:

Func<int, int, int> func = (x, y) => { return x + y; };

但是,在表達(dá)式樹種,只能用第一種寫法,如果使用第二種寫法編譯匯報(bào)錯(cuò)誤:無法將具有語句體的 lambda 表達(dá)式轉(zhuǎn)換為表達(dá)式樹。

除了上邊的寫法,表達(dá)式樹還有可以這么寫:

ParameterExpression pex1 = Expression.Parameter(typeof(int), "x");//第一個(gè)參數(shù)
ParameterExpression pex2 = Expression.Parameter(typeof(int), "y");//第二個(gè)參數(shù)

BinaryExpression bexp = Expression.Add(pex1, pex2);//加法

var lambdaExp = Expression.Lambda<Func<int, int, int>>(bexp, new ParameterExpression[] {pex1,pex2 });

VS調(diào)試模式下可以看到兩種寫法生成的表達(dá)式樹是一樣的

將表達(dá)式樹編譯成委托

LambdaExpression是從Expression派生的類型。泛型類Expression<TDelegate>是從LambdaExpression派生的,其中泛型參數(shù)TDelegate必須是委托類型。

LambdaExpression有個(gè)Compile方法能創(chuàng)建恰當(dāng)類型的一個(gè)委托。而Expression<TDelegate>的Compile方法返回TDelegate類型的委托。來看看下面的例子:

Expression<Func<int, int, int>> expr = (x, y) => x + y;

ParameterExpression pex1 = Expression.Parameter(typeof(int), "x");//第一個(gè)參數(shù)
ParameterExpression pex2 = Expression.Parameter(typeof(int), "y");//第二個(gè)參數(shù)

BinaryExpression bexp = Expression.Add(pex1, pex2);//主體,加法

//使用Expression.Lambda方法,創(chuàng)建一個(gè)委托類型已知的Expression
Expression<Func<int,int,int>> lambdaExp 
    = Expression.Lambda<Func<int, int, int>>(bexp, new ParameterExpression[] { pex1, pex2 });

Func<int,int,int> tDelegate = lambdaExp.Compile();//編譯成委托

Console.WriteLine(tDelegate(1, 3));

Console.Read();

我們運(yùn)行上面代碼,結(jié)果為:4。我們寫了一大堆代碼,本質(zhì)上就是用表達(dá)式樹計(jì)算了1+3的結(jié)果。

看完上述內(nèi)容,你們對C#表達(dá)式樹大概了解了嗎?如果想了解更多相關(guān)文章內(nèi)容,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝各位的閱讀!

新聞標(biāo)題:C#表達(dá)式樹的簡單介紹
網(wǎng)頁鏈接:http://vcdvsql.cn/article8/iipsop.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站策劃網(wǎng)站改版網(wǎng)站制作品牌網(wǎng)站建設(shè)移動網(wǎng)站建設(shè)服務(wù)器托管

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

外貿(mào)網(wǎng)站制作