.net 3.5引入了Linq,lambda運算式,所以委託的建立變得更加簡單和優雅了。
.net 3.5中的委託
引入lambda運算式後,就不需要再使用匿名方法了,使得建立委託的方式更加簡單和優雅。其實如果lambda運算式先引入,那就不會有匿名方法了。
Lambda運算式在C#中的寫法是“arg-list => expr-body”,“=>”符號左邊為運算式的參數列表,右邊則是運算式體(body)。參數列表可以包含0到多個參數,參數之間使用逗號分割。
1 namespace DelegateDemo 2 { 3 //聲明委託 4 public delegate void MyDel(string arg1, string arg2); 5 6 class Program 7 { 8 static void Main(string[] args) 9 {10 //.net 3.5中的委託11 12 //建立委託,使用lambda運算式代替匿名方法13 MyDel myDel = (string arg1, string arg2) =>14 {15 Console.WriteLine(string.Format("arg1:{0},arg2:{1}", arg1, arg2));16 };17 18 //調用委託19 myDel("aaa", "bbb");20 21 Console.ReadKey();22 }23 }24 }
省略參數類型
因為編譯器可以從委託聲明中知道委託參數的類型(這個特性叫做類型推演),所以允許我們省略參數類型,所以代碼簡化成下面這樣。
1 //建立委託,使用lambda運算式代替匿名方法2 MyDel myDel = (arg1, arg2) =>3 {4 Console.WriteLine(string.Format("arg1:{0},arg2:{1}", arg1, arg2));5 };
注,如果只有一個參數,還可以省去參數類型周圍的圓括弧。
使用語句替換運算式
因為lambda運算式允許運算式體是語句或語句塊,所以當運算式體只有一個語句時,可以可以語句代替語句塊,繼續簡化。如下代碼:
1 //建立委託,使用lambda運算式代替匿名方法2 MyDel myDel = (arg1, arg2) => Console.WriteLine(string.Format("arg1:{0},arg2:{1}", arg1, arg2));