五分钟重温C#委托,匿名方法,Lambda,泛型委托,表达式树

五分钟重温C#委托,匿名方法,Lambda,泛型委托,表达式树

https://masuit.com/81

曾经新生代,好多都经过漫长的学习,理解,实践才能掌握委托,表达式树这些应用。今天我尝试用简单的方法叙述一下,让大家在五分钟内看完这篇博客

第一分钟:委托

  有些教材,博客说到委托都会提到事件,虽然事件是委托的一个实例,但是为了理解起来更简单,今天只谈委托不谈事件。先上一段代码:

  下边的代码,完成了一个委托应用的演示。一个委托分三个步骤:


1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

public 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#锦上添花,有人别出心裁给它取个名字叫语法糖。


1

2

3

4

5

6

7

8

9

10

11

public 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表达式的写法:


1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

public 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);

    }

}

  方法一:简单的把delegate去掉,在()与{}之间加上 "=>"。

  方法二:在方法一的基础上把参数类型都干掉了。

  方法三:要干就干彻底些,把{},以及return关键字都去掉了。

  这几种方法随便怎么写都行,不过就是害苦了初学者,一会儿看到这种写法,一会儿看到那种写法,把人搞的神魂颠倒人,如果没人指点,确实会迷糊,难就难在这儿。

第四分钟:泛型委托

  随着.net版本的不升级,新版本总要区别于旧版本吧,不然微软的工程师怎么向他们的老大交差呀?所以微软又来玩新花样了。


1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

public 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<intintint> cAdd2 = (x, y) => { return x + y; };

        int result2 = cAdd2(5, 6);

        //方法三:

        Func<intintint> 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()就可以直接用了。如下代码:


1

2

3

4

5

6

7

8

9

public class Program

{

    static void Main(String[] args)

    {

        Expression<Func<intintint>> exp = (x, y) => x + y;

        Func<intintint> fun = exp.Compile();

        int result = fun(2, 3);

    }

}

  五分钟结束了,我点到的很肤浅,但至少让大家再温习了一篇委托,匿名方法,Lambda,泛型委托,表达式树。

分享到:

微信扫一扫:分享

微信里点“发现”,扫一下

二维码便可将本文分享至朋友圈。

原文地址:https://www.cnblogs.com/xyyhcn/p/12065716.html

时间: 2024-12-11 01:24:34

五分钟重温C#委托,匿名方法,Lambda,泛型委托,表达式树的相关文章

C#中使用委托、接口、匿名方法、泛型委托实现加减乘除算法

使用C#实现加减乘除算法经常被用作新手练习.本篇来分别体验通过委托.接口.匿名方法.泛型委托来实现. 使用委托实现 加减乘除拥有相同的参数个数.类型和返回类型,首先想到了使用委托实现. //创建一个委托 public delegate decimal MathOperation(decimal left, decimal right); //创建方法参数和返回结果符合委托的定义 public static decimal Add(decimal left, decimal right) { re

委托-异步调用-泛型委托-匿名方法-Lambda表达式-事件

1. 委托 From: http://www.cnblogs.com/daxnet/archive/2008/11/08/1687014.html 类是对象的抽象,而委托则可以看成是函数的抽象.一个委托代表了具有相同参数列表和返回值的所有函数. [csharp] view plaincopy class Program { delegate int CalculateDelegate(int a, int b); int add(int a, int b) { return a + b; } s

委托delegate 泛型委托action&lt;&gt; 返回值泛型委托Func&lt;&gt; 匿名方法 lambda表达式 的理解

1.使用简单委托 namespace 简单委托 { class Program { //委托方法签名 delegate void MyBookDel(int a); //定义委托 static MyBookDel myBookDel; //普通方法 public static void MathBook(int a) { Console.WriteLine("我是数学书" + a); } static void Main(string[] args) { myBookDel += Ma

C#委托------匿名方法

namespace out_ref { //委托匿名方法 public delegate void Myadd(); class Program { static void Main(string[] args) { Say(delegate() { Console.WriteLine("哈哈,就是这么帅!"); }); Console.ReadKey(); } static void Say(Myadd myadd) { myadd(); } } } //委托匿名方法 求两个数之和

18、(番外)匿名方法+lambda表达式

概念了解: 1.什么是匿名委托(匿名方法的简单介绍.为什么要用匿名方法) 2.匿名方法的[拉姆达表达式]方法定义 3.匿名方法的调用(匿名方法的参数传递.使用过程中需要注意什么) 什么是匿名方法? 匿名方法是C#2.0引入的一个新特性,它允许开发者声明自己的函数代码而无须使用委托函数. C#为委托提供一种机制,可以为委托定义匿名方法,匿名方法没有名称,编译器会定指定一个名称,匿名方法中不能使用跳转语句跳转到该匿名方法的外部,也不能跳转到该方法的内部.也不能在匿名方法外部使用的ref和out参数.

C# 表达式树 创建、生成、使用、lambda转成表达式树~表达式树的知识详解

笔者最近学了表达式树这一部分内容,为了加深理解,写文章巩固知识,如有错误,请评论指出~ 表达式树的概念 表达式树的创建有 Lambda法 和 组装法. 学习表达式树需要 委托.Lambda.Func<> 基础. 表达式树 形状可以参考 二叉树. 可以把表达式树理解成 数学表达式. 数学表达式的所有常量.符号为表达式树的底节点.每一次计算生成的结果是一个结点,或者说他们的共同结点就是他们应该进行的运算. 生成表达式树 表达式树的创建有 Lambda表达式法 和 组装法 为了方便,这里指定生成的表

委托匿名方法

十二、C# 委托与Lambda表达式(匿名方法的另一种写法)

委托与Lambda表达式 1.委托概述 2.匿名方法 3.语句Lambda 4.表达式Lambda 5.表达式树 一.委托概述 相当于C++当中的方法指针,在C#中使用delegate 委托来提供相同的功能, 它将方法作为对象封装起来,允许在"运行时"间接地绑定一个方法调用. 声明的委托相当于一种自定义的数据类型. 1.背景 冒泡排序 1 static class SimpleSort1 2 { 3 public static void BubbleSort(int[] items)

09.C#委托转换和匿名方法(五章5.1-5.4)

今天将书中看的,自己想的写出来,供大家参考,不足之处请指正.进入正题. 在C#1中开发web form常常会遇到使用事件,为每个事件创建一个事件处理方法,在将方法赋予给事件中,会使用new EventHandler(),不同的事件有各种不同的EventHandler的派生类的实例,因为我这里使用的时Console App,原理是一样的,且看 //定义一个委托 delegate void Printer(); static void Main(string[] args) { Printer p