欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

C#委托,匿名方法,Lambda,泛型委托,表达式树代码示例

程序员文章站 2022-06-14 11:16:55
第一分钟:委托 有些教材,博客说到委托都会提到事件,虽然事件是委托的一个实例,但是为了理解起来更简单,今天只谈委托不谈事件。先上一段代码: 下边的代码,完成了一个委托应用的演示。一个委托分三个步骤: step01:首先用delegate定义一个委托 。 step02:声明一个方法来对应委托。 ste ......

第一分钟:委托

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

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

      

 1 class program
 2     {
 3         //step01:首先用delegate定义一个委托 。
 4         public delegate int calculatoradd(int x, int y);
 5         static void main(string[] args)
 6         {
 7             //step03:用这个方法来实例化这个委托。
 8             calculatoradd cadd = new calculatoradd(add);
 9             //int result = cadd(5, 6);
10             int result = cadd.invoke(5, 6);
11         }
12         // step02:声明一个方法来对应委托。
13         public static int add(int x, int y)
14         {
15             return x + y;
16 
17         }
18 
19 
20     }

 

    step01:首先用delegate定义一个委托 。

  step02:声明一个方法来对应委托。

  step03:用这个方法来实例化这个委托。

  至此,一个委托的应该就完成了,就可以调用委托了。

 第二分钟:匿名方法

  在上一分钟已经知道了,完成一个委托应用分三步走,缺一步都不行,如果要跨大步,当心步子大了扯着蛋。但是微软不怕扯着蛋,非要把三步做成两步来走啊!所以微软就用匿名方法来简化上边的三个步骤。匿名方法这个玩意儿怎么说呢,在c#中完全是可有可无的东西,只是为c#锦上添花,有人别出心裁给它取个名字叫语法糖。

 1  class program
 2     {
 3         //step01:首先用delegate定义一个委托 。
 4         public delegate int calculatoradd(int x, int y);
 5         static void main(string[] args)
 6         {
 7             //step02:用这样的写法 delegate(int x, int y) { return x + y; },把一个方法赋值给委托
 8             calculatoradd cadd = delegate (int x, int y) { return x + y; };
 9             int result = cadd.invoke(5, 6);
10         }
11        
12 
13 
14     }

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