第一分鐘:委託
有些教材、部落格說到委託都會提到事件,雖然事件是委託的一個實例,但是為了理解起來更簡單,今天只談委託不談事件。先上一段程式碼:
下邊的程式碼,完成了一個委託應用的示範。一個委託分三個步驟:
class Program
{
//step01:首先用delegate定義一個委託 。
public delegate int CalculatorAdd(int x, int y);
static void Main(string[] args)
{
//step03:用這個方法來實例化這個委託。
CalculatorAdd cAdd = new CalculatorAdd(Add);
//int result = cAdd(5, 6);
int result = cAdd.Invoke(5, 6);
}
// step02:宣告一個方法來對應委託。
public static int Add(int x, int y)
{
return x + y;
}
}
step01:首先用delegate定義一個委託 。- step02:宣告一個方法來對應委託。
- step03:用這個方法來實例化這個委託。
至此,一個委託的應用就完成了,就可以呼叫委託了。
第二分鐘:匿名方法
在上一分鐘已經知道了,完成一個委託應用分三步走,缺一步都不行,如果要跨大步,當心步子大了扯著蛋。但是微軟不怕扯著蛋,非要把三步做成兩步來走啊!所以微軟就用匿名方法來簡化上邊的三個步驟。匿名方法這個玩意兒怎麼說呢,在 C#中完全是可有可無的東西,只是為 C#錦上添花,有人別出心裁給它取個名字叫語法糖。
class Program
{
//step01:首先用delegate定義一個委託 。
public delegate int CalculatorAdd(int x, int y);
static void Main(string[] args)
{
//step02:用這樣的寫法 delegate(int x, int y) { return x + y; },把一個方法賦值給委託
CalculatorAdd cAdd = delegate (int x, int y) { return x + y; };
int result = cAdd.Invoke(5, 6);
}
}
- 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);
}
}