C#委托,匿名方法,Lambda,泛型委托,表達式樹代碼示例


第一分鍾:委托

 有些教材,博客說到委托都會提到事件,雖然事件是委托的一個實例,但是為了理解起來更簡單,今天只談委托不談事件。先上一段代碼:

  下邊的代碼,完成了一個委托應用的演示。一個委托分三個步驟:

      

 1 class Program
 2     {
 3         //step01:首先用delegate定義一個委托 。
 4         public delegate int CalculatorAdd(int x, int y);
 5         static void Main(string[] args)
 6         {
 7             //step03:用這個方法來實例化這個委托。
 8             CalculatorAdd cAdd = new CalculatorAdd(Add);
 9             //int result = cAdd(5, 6);
10             int result = cAdd.Invoke(5, 6);
11         }
12         // step02:聲明一個方法來對應委托。
13         public static int Add(int x, int y)
14         {
15             return x + y;
16 
17         }
18 
19 
20     }

 

    step01:首先用delegate定義一個委托 。

  step02:聲明一個方法來對應委托。

  step03:用這個方法來實例化這個委托。

  至此,一個委托的應該就完成了,就可以調用委托了。

 第二分鍾:匿名方法

  在上一分鍾已經知道了,完成一個委托應用分三步走,缺一步都不行,如果要跨大步,當心步子大了扯着蛋。但是微軟不怕扯着蛋,非要把三步做成兩步來走啊!所以微軟就用匿名方法來簡化上邊的三個步驟。匿名方法這個玩意兒怎么說呢,在C#中完全是可有可無的東西,只是為C#錦上添花,有人別出心裁給它取個名字叫語法糖。

 1  class Program
 2     {
 3         //step01:首先用delegate定義一個委托 。
 4         public delegate int CalculatorAdd(int x, int y);
 5         static void Main(string[] args)
 6         {
 7             //step02:用這樣的寫法 delegate(int x, int y) { return x + y; },把一個方法賦值給委托
 8             CalculatorAdd cAdd = delegate (int x, int y) { return x + y; };
 9             int result = cAdd.Invoke(5, 6);
10         }
11        
12 
13 
14     }

  step01:首先用delegate定義一個委托 。

  step02:用這樣的寫法 delegate(int x, int y) { return x + y; },把一個方法賦值給委托,其實這種寫法就是匿名方法。

  這時會驚奇的發現,這不是三步當着兩步走了哇?

   第三分鍾:Lambda表達式

  原本很簡單的程序,加上幾個delegate關鍵字,這代碼一下就變得深奧了,深奧的東西懂的人就變少了,所以這個還可以作為加薪的籌碼。但是微軟對C#的設計理念是簡單易用。微軟就想方設法的來簡化delegate(int x, int y) { return x + y; }這個匿名方法,Lambda就出現了。下邊我來看幾種lambda表達式的寫法:

 class Program
    {
        public delegate int CalculatorAdd(int x, int y);
        static void Main(string[] args)
        {

            //方法一:
            CalculatorAdd cAdd1 = (int x, int y) => { return x + y; };
            int result1 = cAdd1(5, 6);
            //方法二:
            CalculatorAdd cAdd2 = (x, y) => { return x + y; };
            int result2 = cAdd2(5, 6);
            //方法三:
            CalculatorAdd cAdd3 = (x, y) => x + y;
            int result3 = cAdd2(5, 6);
        }
    }

 

     第四分鍾:泛型委托

  隨着.net版本的不升級,新版本總要區別於舊版本吧,不然微軟的工程師怎么向他們的老大交差呀?所以微軟又來玩新花樣了。

 class Program
    {
     
        static void Main(string[] args)
        {
            //方法一:
            Func<int, int, int> cAdd1 = (int x, int y) => { return x + y; };
            int result1 = cAdd1(5, 6);
            //方法二:
            Func<int, int, int> cAdd2 = (x, y) => { return x + y; };
            int result2 = cAdd2(5, 6);
            //方法三:
            Func<int, int, int> cAdd3 = (x, y) => x + y;
            int result3 = cAdd2(5, 6);
        }
    }

 

 

 不管是匿名方法還是Lambda表達式,完成一個委托的應用,都逃不過兩個步驟,一步是定義一個委托,另一步是用一個方法來實例化一個委托。 微軟干脆把這兩步都合成一步來走了。用Func來簡化一個委托的定義。

  至此一個委托的應用就可用 Func<int, int, int> cAdd3 = (x, y) => x + y; 這樣一句話來完成了,其中的Func就是所謂的泛型委托。

  第五分鍾:表達式樹

  表達式樹其實與委托已經沒什么關系了,非要扯上關系,那就這么說吧,表達式樹是存放委托的容器。如果非要說的更專業一些,表達式樹是存取Lambda表達式的一種數據結構。要用Lambda表達式的時候,直接從表達式中獲取出來,Compile()就可以直接用了。如下代碼:

 

class Program
    {
     
        static void Main(string[] args)
        {

            Expression<Func<int, int, int>> exp = (x, y) => x + y;
            Func<int, int, int> fun = exp.Compile();
            int result = fun(2, 3);
        }
    }

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM