亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

C# 3.0新特性體驗之Lambda表達式

2019-11-18 17:16:40
字體:
來源:轉載
供稿:網友
  C#2.0介紹了一個新特性--匿名方法,允許開發者在線(inline)聲明自己的函數代碼而無須使用委托函數(delegate function)。C#3.0中提供了一個新特性--Lambda表達式,它提供了完成相同目標的更加簡潔的格式。讓我們在討論Lambda表達式以前仔細研究一下匿名方法。

  匿名方法

  假設你需要創建一個按鈕,當點擊它的時候更新ListBox里的內容。在C#1.0和1.1里,你要這樣做:

public MyForm()
{
 listBox = new ListBox(...);
 textBox = new TextBox(...);
 addButton = new Button(...);
 addButton.Click += new EventHandler(AddClick);
}

void AddClick(object sender, EventArgs e)
{
 listBox.Items.Add(textBox.Text);
}

  在C#2.0里,你需要這樣做:

public MyForm()
{
 listBox = new ListBox(...);
 textBox = new TextBox(...);
 addButton = new Button(...);
 addButton.Click += delegate
 {
  listBox.Items.Add(textBox.Text);
};

  就像你看到的一樣,你不必要特別的聲明一個新方法來將它連接到一個事件上。你可以在C#2.0里使用匿名方法來完成同樣的工作。C#3.0里介紹了一種更加簡單的格式,Lambda表達式,你可以直接使用"=>"來書寫你的表達式列表,后面跟上一個表達式或者語句塊。

  Lambda表達式中的參數

  Lambda表達式中的參數可以是顯式或者隱式類型的。在一個顯式類型參數列表里,每個表達式的類型是顯式指定的。在一個隱式類型參數列表里,類型是通過上下文推斷出來的:

(int x) => x + 1 // 顯式類型參數
(y,z) => return y * z; // 隱式類型參數

  Lambda演算實例

  下面的例子給出了兩種不同的方法來打印出一個list中長度為偶數的字符串。第一種方法AnonMethod使用了匿名方法,第二種LambdaExample則是通過Lambda演算實現:

// PRogram.cs
using System;
using System.Collections.Generic;
using System.Text;
using System.Query;
using System.xml.XLinq;
using System.Data.DLinq;

namespace LambdaExample
{
 public delegate bool KeyValueFilter<K, V>(K key, V value);
 static class Program
 {

  static void Main(string[] args)
  {
   List<string> list = new List<string>();

   list.Add("AA");
   list.Add("ABC");
   list.Add("DEFG");
   list.Add("XYZ");
   Console.WriteLine("Through Anonymous method");
   AnonMethod(list);
   Console.WriteLine("Through Lambda expression");
   LambdaExample(list);

   Dictionary<string, int> varClothes= new Dictionary<string,int>();

   varClothes.Add("Jeans", 20);
   varClothes.Add("Shirts", 15);
   varClothes.Add("Pajamas", 9);
   varClothes.Add("Shoes", 9);
   var ClothesListShortage = varClothes.FilterBy((string name,
   int count) => name == "Shoes" && count < 10);
   // example of multiple parameters
   if(ClothesListShortage.Count > 0)
    Console.WriteLine("We are short of shoes");
   Console.ReadLine();
 }

 static void AnonMethod(List<string> list)
 {
  List<string> evenNumbers = list.FindAll(delegate(string i)
  { return (i.Length % 2) == 0; });
  foreach (string evenNumber in evenNumbers)
  {
   Console.WriteLine(evenNumber);
  }
 }

 static void LambdaExample(List<string> list)
 {
  var evenNumbers = list.FindAll(i =>(i.Length % 2) == 0); // example of single parameter
  foreach(string i in evenNumbers)
  {
   Console.WriteLine(i);
  }
 }
}

public static class Extensions
{
 public static Dictionary<K, V> FilterBy<K, V>
(this Dictionary<K, V> items, KeyValueFilter<K, V> filter)
 {
  var result = new Dictionary<K, V>();
  foreach(KeyValuePair<K, V> element in items)
  {
   if (filter(element.Key, element.Value))
    result.Add(element.Key, element.Value);
  }
  return result;
 }
 
}
}

  如果你安裝了Visual Studio 2005 and LinQ Preview,你可以使用編輯器來編譯程序。如果沒有的話,可以使用命令行方式:

C:/Program Files/LINQ Preview/Bin/Csc.exe
/reference:"C:/Program Files/LINQ Preview/Bin/System.Data.DLinq.dll"
/reference:C:/WINDOWS/Microsoft.NET/Framework/v2.0.50727/System.Data.dll
/reference:C:/WINDOWS/Microsoft.NET/Framework/v2.0.50727/System.dll
/reference:"C:/Program Files/LINQ Preview/Bin/System.Query.dll"
/reference:C:/WINDOWS/Microsoft.NET/Framework/v2.0.50727/System.Xml.dll
/reference:"C:/Program Files/LINQ Preview/Bin/System.Xml.XLinq.dll"
/target:exe Program.cs

  中間語言結果顯示

  打開ILDASM我們來查看一下程序,你將看到如圖1所示的內容:


圖1

  雙擊AnonMethod函數你將看到C#編譯器產生的中間語言代碼:

.method private hidebysig static void AnonMethod(class
[mscorlib]System.Collections.Generic.List`1<string> list)
cil managed
{
 // Code size 96 (0x60)
 .maxstack 4
 .locals init ([0] class [mscorlib]System.Collections.Generic.List
 `1<string> evenNumbers,
 [1] string evenNumber,
 [2] valuetype [mscorlib]System.Collections.Generic.List
 `1/Enumerator<string> CSCODE_REPLACEMENT 000,
 [3] bool CSCODE_REPLACEMENT 001)
 IL_0000: nop
 IL_0001: ldarg.0
 IL_0002: ldsfld class [mscorlib]System.Predicate
 `1<string> LambdaExample.Program::
 `<>9__CachedAnonymousMethodDelegate1'
 IL_0007: brtrue.s IL_001c
 IL_0009: ldnull
 IL_000a: ldftn bool LambdaExample.Program::
 `<AnonMethod>b__0'(string)
 IL_0010: newobj instance void class [mscorlib]System.Predicate
 `1<string>::.ctor(object, native int)
 IL_0015: stsfld class [mscorlib]System.Predicate`1<string>
 LambdaExample.Program::
 `<>9__CachedAnonymousMethodDelegate1'
 IL_001a: br.s IL_001c
 IL_001c: ldsfld class [mscorlib]System.Predicate`1<string>
 LambdaExample.Program::'<>
 9__CachedAnonymousMethodDelegate1'
 IL_0021: callvirt instance class [mscorlib]System.Collections.
 Generic.List`1<!0> class [mscorlib]System.
 Collections.Generic.List`1<string>::
 FindAll(class [mscorlib]System.Predicate`1<!0>)
 IL_0026: stloc.0
 IL_0027: nop
 IL_0028: ldloc.0
 IL_0029: callvirt instance valuetype [mscorlib]System.Collections.
 Generic.List`1/Enumerator<!0> class
 [mscorlib]System.Collections.Generic.List`1
 <string>::GetEnumerator()
 IL_002e: stloc.2
 .try
 {
  IL_002f: br.s IL_0042
  IL_0031: ldloca.s CSCODE_REPLACEMENT 000
  IL_0033: call instance !0 valuetype [mscorlib]System.
  Collections.Generic.List`1/Enumerator
  <string>::get_Current()
  IL_0038: stloc.1
  IL_0039: nop
  IL_003a: ldloc.1
  IL_003b: call void [mscorlib]System.Console::
  WriteLine(string)
  IL_0040: nop
  IL_0041: nop
  IL_0042: ldloca.s CSCODE_REPLACEMENT 000
  IL_0044: call instance bool valuetype [mscorlib]System.
  Collections.Generic.List`1/Enumerator
  <string>::MoveNext()
  IL_0049: stloc.3
  IL_004a: ldloc.3
  IL_004b: brtrue.s IL_0031
  IL_004d: leave.s IL_005e
 } // end .try
 finally
 {
  IL_004f: ldloca.s CSCODE_REPLACEMENT 000
  IL_0051: constrained. valuetype [mscorlib]System.Collections.
  Generic.List`1/Enumerator<string>
  IL_0057: callvirt instance void [mscorlib]System.
  IDisposable::Dispose()
  IL_005c: nop
  IL_005d: endfinally
 } // end handler
 IL_005e: nop
 IL_005f: ret
} // end of method Program::AnonMethod

  這里我們可以看到,實際上匿名方法和lambda表達式生成了相同的中間代碼,并且他們的執行也是類似的。

  多參數的Lambda表達式

  Lambda表達式可以帶上多個參數,比如你可以聲明一個Dictionary類型:

Clothing TypeCount
Shirts15
Jeans12
Shoes 9
Pajamas9

  如果你有一個匿名方法(FilterBy)來通過鍵和值來過濾字典,按么你可以傳遞多個參數給lambda表達式來調用這個匿名方法。附帶的代碼完成了這個FilterBy的功能:

var ClothesListShortage = clothesList.FilterBy((string name, int count)
=> name == "Shoes" && count < 10);

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产精品美乳在线观看| 亚洲免费一在线| 欧美中文字幕精品| 在线成人激情黄色| 另类图片亚洲另类| 亚洲天堂久久av| 国产欧美日韩综合精品| 欧美大尺度电影在线观看| 欧美一乱一性一交一视频| 一区二区三区久久精品| 欧美大片va欧美在线播放| 精品视频www| 亚洲色图激情小说| 国产热re99久久6国产精品| 日本精品久久久久影院| 亚洲aⅴ男人的天堂在线观看| 亚洲精品小视频在线观看| 日韩欧美在线观看视频| 国产精品自产拍在线观看| 国产99久久精品一区二区| 性色av香蕉一区二区| 日韩视频在线一区| 日本精品久久久久久久| 成人有码视频在线播放| 国产精品久久久久久久久久久久久| 国产精品18久久久久久首页狼| 一区二区三区视频免费| 国产mv久久久| 亚洲日本aⅴ片在线观看香蕉| 中文字幕日韩视频| 国产精品久久久久久久久久久久久| 国产在线精品一区免费香蕉| 2021国产精品视频| 亚洲精品国产精品国自产观看浪潮| 久久精品成人一区二区三区| 91亚洲va在线va天堂va国| 国模精品系列视频| 欧美日韩国产中文字幕| 欧美风情在线观看| 亚洲精品动漫100p| 国产日韩精品一区二区| 亚洲一区二区三区久久| 国产午夜精品麻豆| 7777kkkk成人观看| 亚洲视频一区二区| 色播久久人人爽人人爽人人片视av| 午夜精品一区二区三区在线视频| 久久91亚洲精品中文字幕| 久久精品国产一区二区三区| 久久久久久亚洲精品中文字幕| 国产精品一区二区三区成人| 久久综合免费视频| 精品毛片网大全| 日韩久久午夜影院| 国产亚洲成av人片在线观看桃| www国产亚洲精品久久网站| 国产精品三级网站| 日韩资源在线观看| 精品福利免费观看| 欧美性高潮在线| 欧美日韩在线影院| 精品久久久久久亚洲精品| 在线国产精品视频| 成人精品一区二区三区| 成人av在线天堂| 亚洲国产另类 国产精品国产免费| 国产一区二区三区精品久久久| 久久久久久美女| 亚洲天堂影视av| 91精品视频免费观看| 亚洲毛茸茸少妇高潮呻吟| 亚洲伊人一本大道中文字幕| 日韩一区在线视频| 成人免费在线视频网址| 国产欧美日韩丝袜精品一区| 最新91在线视频| 国产一区二区三区在线免费观看| 欧美精品久久久久久久| 亚洲精品第一国产综合精品| 精品福利在线观看| 亚洲第一福利视频| 国产精品91久久| 国产美女精彩久久| 日韩免费在线观看视频| 国内成人精品视频| 5566成人精品视频免费| 国内外成人免费激情在线视频| 性欧美亚洲xxxx乳在线观看| 中文字幕综合在线| 一区二区三区 在线观看视| 欧美性极品少妇精品网站| 超薄丝袜一区二区| 中文字幕欧美在线| 日韩一中文字幕| 尤物九九久久国产精品的特点| 一夜七次郎国产精品亚洲| 狠狠做深爱婷婷久久综合一区| 九九综合九九综合| 欧美裸体xxxxx| 欧美电影免费观看高清完整| 精品久久久香蕉免费精品视频| 亚洲国产精久久久久久久| 国产精品久久久久av免费| 久久精品国产亚洲精品2020| 日韩中文理论片| 欧美成人午夜影院| 欧美成人一区二区三区电影| 午夜精品一区二区三区在线| 亚洲精品日韩激情在线电影| 欧美性理论片在线观看片免费| 欧美激情乱人伦一区| 中文字幕少妇一区二区三区| 97精品伊人久久久大香线蕉| 国产精欧美一区二区三区| 欧美电影在线观看高清| 亚洲男人av电影| 亚洲**2019国产| 国产精品www色诱视频| 欧美性xxxx在线播放| 日韩精品极品在线观看| 日韩av在线免费看| 美日韩丰满少妇在线观看| 欧美日韩成人黄色| 久久久亚洲国产| 最近2019年好看中文字幕视频| 国产精品一区二区久久久久| 欧美极品少妇全裸体| 福利一区视频在线观看| 77777亚洲午夜久久多人| 色综合91久久精品中文字幕| 日韩hd视频在线观看| 精品久久久视频| 久久久久五月天| 国产日韩欧美在线视频观看| 38少妇精品导航| 成人日韩在线电影| 91在线观看免费高清完整版在线观看| 一区二区国产精品视频| 亚洲男人的天堂在线| 欧美黄色成人网| 久久久噜噜噜久久中文字免| 91国自产精品中文字幕亚洲| 欧美贵妇videos办公室| 日韩乱码在线视频| 欧美极品少妇xxxxⅹ喷水| 97热在线精品视频在线观看| 国产精品∨欧美精品v日韩精品| 欧美成人精品激情在线观看| 日韩中文字幕视频在线观看| 在线成人一区二区| 成人午夜激情免费视频| 日韩av日韩在线观看| 韩曰欧美视频免费观看| 亚洲成色777777女色窝| 欧美激情一区二区三区久久久| 亚洲偷欧美偷国内偷| 国产欧美在线观看| 久久成人人人人精品欧| 日韩在线免费视频| 亚洲欧美在线免费观看| 在线午夜精品自拍| 欧美一区深夜视频| 97香蕉久久夜色精品国产| 亚洲性猛交xxxxwww|