真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

.Net4.0中委托delegate的使用方法-創(chuàng)新互聯(lián)

這篇文章主要介紹“.Net 4.0 中委托delegate的使用方法”,在日常操作中,相信很多人在.Net 4.0 中委托delegate的使用方法問題上存在疑惑,小編查閱了各式資料,整理出簡(jiǎn)單好用的操作方法,希望對(duì)大家解答”.Net 4.0 中委托delegate的使用方法”的疑惑有所幫助!接下來,請(qǐng)跟著小編一起來學(xué)習(xí)吧!

五龍口ssl適用于網(wǎng)站、小程序/APP、API接口等需要進(jìn)行數(shù)據(jù)傳輸應(yīng)用場(chǎng)景,ssl證書未來市場(chǎng)廣闊!成為創(chuàng)新互聯(lián)公司的ssl證書銷售渠道,可以享受市場(chǎng)價(jià)格4-6折優(yōu)惠!如果有意向歡迎電話聯(lián)系或者加微信:18980820575(備注:SSL證書合作)期待與您的合作!

.Net中的委托從功能上講和c語(yǔ)言或者c++中的方法指針類似,可以像調(diào)用方法一樣調(diào)用委托完成某個(gè)功能,或返回某類結(jié)果。但是.Net畢竟是更高級(jí)的語(yǔ)言,委托Delegate也更高級(jí)了,委托是一種數(shù)據(jù)接口,它包含調(diào)用目標(biāo)和調(diào)用方法的指針;而在.Net中定義的委托都繼承自MulticastDelegate即多播委托,所謂的多播委托是指可以包含多個(gè)調(diào)用方法的委托。
一. 先來看下委托的定義:
如下C#代碼定義委托
public delegate void DoSomething(int times);
委托的定義包含5個(gè)部分
1) public表示委托的可訪問性
2) delegate關(guān)鍵字表示要定義一個(gè)委托
3) void表示委托定義方法的返回值
4) DoSomething是委托的名字
5) (int times) 是委托方法的參數(shù)列表,此處的參數(shù)列表可以包括ref參數(shù),也可以有out參數(shù),同樣也可以有parms可變數(shù)量參數(shù);需要注意如果委托中有多個(gè)調(diào)用方法,使用out參數(shù)時(shí)只能返回委托最后執(zhí)行成功的一個(gè)委托方法的計(jì)算值
在C#中定義委托非常簡(jiǎn)單,只比方法定義的返回值之前多一個(gè)delegate關(guān)鍵字即可。
可是我們知道所有的用戶定義委托都繼承自MulticastDelegate;而MulticastDelegate是一個(gè)類;所以自定義的委托肯定也是一個(gè)類;看下上述代碼的IL代碼就可以證明我們的推斷:


復(fù)制代碼 代碼如下:


.class public auto ansi sealed delegates.DoSomething
    extends [mscorlib]System.MulticastDelegate
{
    // Methods
    .method public hidebysig specialname rtspecialname
        instance void .ctor (
            object 'object',
            native int 'method'
        ) runtime managed
    {
    } // end of method DoSomething::.ctor

    .method public hidebysig newslot virtual
        instance void Invoke (
            int32 times
        ) runtime managed
    {

    } // end of method DoSomething::Invoke

 
    .method public hidebysig newslot virtual
        instance class [mscorlib]System.IAsyncResult BeginInvoke (
            int32 times,
            class [mscorlib]System.AsyncCallback callback,
            object 'object'
        ) runtime managed
    {

    } // end of method DoSomething::BeginInvoke

 
    .method public hidebysig newslot virtual
        instance void EndInvoke (
            class [mscorlib]System.IAsyncResult result
        ) runtime managed
    {

    } // end of method DoSomething::EndInvoke

} // end of class delegates.DoSomething



二. 定義了委托,當(dāng)然是為了使用它,來看下如何使用委托:
在.Net中有三種委托的形式,分別是方法、匿名方法和lambda表達(dá)式;我們用方法定義的形式看下委托的使用方法


復(fù)制代碼 代碼如下:


using System;

namespace delegates
{
 public delegate void DoSomething(int times);

    class Program
    {
        static void Main(string[] args)
        {
            //聲明委托變量并給委托變量賦值
            DoSomething @do = DoA;
            //可以使用+號(hào)或者+=給委托增加方法
            @do += DoB;
            //執(zhí)行委托時(shí)將按照委托的添加順序先后執(zhí)行委托中的方法
            @do(1);
            //也可以通過-號(hào)或者-= 從委托中移除方法
            @do -= DoA;
            @do(2);

            @do -= DoB;
            //將委托中的所有方法都移除掉之后,委托照樣是可以調(diào)用的,只是什么都不做
            @do(3);

            Console.Read();
        }
       //定義一個(gè)委托相同參數(shù)和返回值的方法
        static void DoA(int times)
        {
            Console.WriteLine("Do A {0}", times);
        }

 
        //定義一個(gè)委托相同參數(shù)和返回值的方法
        static void DoB(int times)
        {
            Console.WriteLine("Do B {0}", times);
        }
    }
}



如上代碼中的Main方法,首先我們定義了委托DoSomething的變量@do,并將DoA方法直接賦值給此委托變量;然后我們又使用+=符號(hào)或者+號(hào)給此委托添加了另一個(gè)方法;當(dāng)然也可以使用-或者-=從委托中去掉方法。
委托比C/C++方法指針強(qiáng)大的地方在于其可以容納多個(gè)方法,也可以執(zhí)行+/-操作從方法列表中添加或者刪除掉方法。
在執(zhí)行委托加減運(yùn)算時(shí)有幾個(gè)問題需要我們注意:
1. 委托聲明的寫法
委托聲明時(shí)可以用如下寫法


復(fù)制代碼 代碼如下:


DoSomething @do = DoA;



這其實(shí)是一種簡(jiǎn)短的寫法,我們知道在.Net 1.x中這樣寫是不允許的只有到.Net 2.0時(shí)才允許這么寫,在.Net 1.x中必須寫成


復(fù)制代碼 代碼如下:


DoSomething @do = new DoSomething(DoA);



我們要在聲明時(shí)就給@do賦予DoA加上DoB


復(fù)制代碼 代碼如下:


DoSomething @do = DoA + DoB;



這么寫是不行的,編譯器不干了;必須使用.Net 1.x中的寫法


復(fù)制代碼 代碼如下:


DoSomething @do = new DoSomething(DoA) + new DoSomething(DoB);



2. 從委托中減去委托中本不存在的方式時(shí)會(huì)發(fā)生什么呢?
請(qǐng)看如下代碼:


復(fù)制代碼 代碼如下:


DoSomething @do = DoA;
@do -= DoB;



第一行代碼我生命了@do并將DoA賦予它;第二行代碼我嘗試從@do中減去DoB,DoB并沒有在@do的方法列表中存在,這樣會(huì)發(fā)生什么情況呢?首先編譯器沒有報(bào)錯(cuò),程序可以正常的編譯;執(zhí)行代碼發(fā)現(xiàn)可以程序可以正常執(zhí)行,調(diào)用@do委托時(shí)正確的執(zhí)行了DoA方法;這說明了.Net包容了我們程序員犯的錯(cuò),我們從委托變量中減去一個(gè)委托中并不包含的方法時(shí),不會(huì)報(bào)錯(cuò)會(huì)正常的執(zhí)行。
3. 對(duì)委托做減法,所有委托都減完了,會(huì)怎樣呢?看如下代碼


復(fù)制代碼 代碼如下:


DoSomething @do = new DoSomething(DoA) + new DoSomething(DoB);
@do -= DoA;
@do -= DoB;
@do(1);



這樣的代碼可以成功編譯,但是在運(yùn)行時(shí)會(huì)報(bào)NullReferenceException;這顯然不是我們希望的,所以對(duì)委托做減法時(shí)要特別注意。


復(fù)制代碼 代碼如下:


public delegate void DoIt(string task);

class Test
{
    static void Main(string[] args)
    {
        //DoIt聲明,賦予一個(gè)參數(shù)更寬泛的方法是合法的
        DoIt doIt = new DoIt(DoItImpl);
        doIt("hello");
    }

    //比委托定義中的參數(shù)更寬泛,string類型可以隱式轉(zhuǎn)換成object
    static void DoItImpl(object task)
    {
        Console.WriteLine("DoItImpl {0}",task);
    }
}


到此,關(guān)于“.Net 4.0 中委托delegate的使用方法”的學(xué)習(xí)就結(jié)束了,希望能夠解決大家的疑惑。理論與實(shí)踐的搭配能更好的幫助大家學(xué)習(xí),快去試試吧!若想繼續(xù)學(xué)習(xí)更多相關(guān)知識(shí),請(qǐng)繼續(xù)關(guān)注創(chuàng)新互聯(lián)網(wǎng)站,小編會(huì)繼續(xù)努力為大家?guī)砀鄬?shí)用的文章!


文章標(biāo)題:.Net4.0中委托delegate的使用方法-創(chuàng)新互聯(lián)
轉(zhuǎn)載來于:http://weahome.cn/article/ccpigp.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部