帶你重溫C#委託,匿名方法,Lambda,泛型委託,表達式樹代碼範例
帶你重溫C#委託,匿名方法,Lambda,泛型委託,表達式樹代碼範例:
這些對老一代的程式設計師都是老生常談的東西,沒什麼新意,對新生代的程式設計師卻充滿著魅力。曾經新生代,好多都經過漫長的學習,理解,實踐才能掌握委託,表達式樹這些應用。今天我試著用簡單的方法敘述一下,讓大家在五分鐘內看完這篇部落格。
# 第一分鐘:委託
# 有些教材,博客說到委託都會提到事件,雖然事件是委託的一個實例,但是為了理解起來更簡單,今天只談委託不談事件。先上一段程式碼:
下邊的程式碼,完成了一個委託應用的示範。一個委託分三個步驟:
public partial class WebForm3 : System.Web.UI.Page { //step01:首先用delegate定义一个委托 。 public delegate int CalculatorAdd(int x, int y); protected void Page_Load(object sender, EventArgs e) { //step03:用这个方法来实例化这个委托。 CalculatorAdd cAdd = new CalculatorAdd(Add); //int result = cAdd(5, 6); int result = cAdd.Invoke(5,6); } // step02:声明一个方法来对应委托。 public int Add(int x, int y) { return x + y; } }
step01:首先用delegate定義一個委託 。
step02:宣告一個方法來對應委託。
step03:用這個方法來實例化這個委託。
至此,一個委託的應該就完成了,就可以調用委託了。
第二分鐘:匿名方法
在上一分鐘已經知道了,完成一個委託應用分三步走,缺一步都不行,如果要跨大步,當心步子大了扯著蛋。但是微軟不怕扯著蛋,非要把三步驟做成兩步來走啊!所以微軟就用匿名方法來簡化上邊的三個步驟。匿名方法這個玩意兒怎麼說呢,在C#中完全是可有可無的東西,只是為C#錦上添花,有人別出心裁給它取個名字叫語法糖。
public partial class WebForm3 : System.Web.UI.Page { //step01:首先用delegate定义一个委托 public delegate int CalculatorAdd(int x, int y); protected void Page_Load(object sender, EventArgs e) { //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表達式的寫法:
public partial class WebForm3 : System.Web.UI.Page { public delegate int CalculatorAdd(int x, int y); protected void Page_Load(object sender, EventArgs e) { //方法一: 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); } }
方法一:簡單的把delegate去掉,在()與{}之間加上 "=>"。
方法二:在方法一的基礎上把參數型別都乾掉了。
方法三:要乾就乾徹底些,把{},以及return關鍵字都去掉了。
這幾種方法隨便怎麼寫都行,不過就是害苦了初學者,一會兒看到這種寫法,一會兒看到那種寫法,把人搞的神魂顛倒人,如果沒人指點,確實會迷糊,難就難在這兒。
第四分鐘:泛型委託
隨著.net版本的不升級,新版本總要區別於舊版吧,不然微軟的工程師怎麼向他們的老大交差呀?所以微軟又來玩新花樣了。
public partial class WebForm3 : System.Web.UI.Page { protected void Page_Load(object sender, EventArgs e) { //方法一: 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
第五分鐘:表達式樹
表達式樹其實與委託已經沒什麼關係了,非要扯上關係,那就這麼說吧,表達式樹是存放委託的容器。如果非要說的更專業一些,表達式樹是訪問Lambda表達式的一種資料結構。要用Lambda表達式的時候,直接從表達式中取得出來,Compile()就可以直接用了。如下程式碼:
public partial class WebForm3 : System.Web.UI.Page { protected void Page_Load(object sender, EventArgs e) { Expression<Func<int, int, int>> exp = (x, y) => x + y; Func<int, int, int> fun = exp.Compile(); int result = fun(2, 3); } }
我點到的很膚淺,但至少讓大家再溫習了一篇委託,匿名方法,Lambda,泛型委託,表達式樹。
以上是帶你重溫C#委託,匿名方法,Lambda,泛型委託,表達式樹代碼範例的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

在C++中,使用Lambda表達式處理異常有兩種方法:使用try-catch區塊捕獲異常,並在catch區塊中處理或重新拋出異常。使用std::function類型的包裝函數,其try_emplace方法可以捕獲Lambda表達式中的異常。

在C++中,閉包是能夠存取外部變數的lambda表達式。若要建立閉包,請擷取lambda表達式中的外部變數。閉包提供可重複使用性、資訊隱藏和延遲求值等優點。它們在事件處理程序等實際情況中很有用,其中即使外部變數被銷毀,閉包仍然可以存取它們。

lambda表達式在C++多執行緒程式設計中的優點包括:簡潔性、靈活性、易於傳參和並行性。實戰案例:使用lambda表達式建立多執行緒,在不同執行緒中列印執行緒ID,展示了該方法的簡潔和易用性。

C++Lambda表達式支援閉包,即保存函數作用域變數並供函數存取。語法為[capture-list](parameters)->return-type{function-body}。 capture-list定義要捕獲的變量,可以使用[=]按值捕獲所有局部變量,[&]按引用捕獲所有局部變量,或[variable1,variable2,...]捕獲特定變量。 Lambda表達式只能存取捕獲的變量,但無法修改原始值。

在C++中捕捉外部變數的lambda表達式有三種方法:按值擷取:建立一個變數副本。按引用擷取:獲得變數引用。同時按值和引用捕獲:允許捕獲多個變量,按值或按引用。

在C++中,可以使用Lambda表達式作為函數參數,實現回呼函數的靈活性。具體而言:參數傳遞:透過std::function包裝Lambda表達式,以函數指標形式傳遞給函數。傳回值處理:使用std::function宣告回呼函數指標時指定傳回值類型。實戰案例:優化GUI事件處理中的回調,避免創建不必要的物件或函數指針,提高程式碼簡潔性和可維護性。

如何使用C++lambda表達式執行延遲求值?使用lambda表達式建立延遲求值的函數物件。延遲計算推遲到需要時才執行。僅當需要時才計算結果,提高效能。

以lambda表達式取代函數指標可提升可讀性、減少樣板程式碼並提高重用性。具體而言,lambda表達式採用以下語法:[capturelist](parameterlist)->returntype{body},並可用於對向量排序等實戰案例中,提升程式碼簡潔性和可維護性。
