一、委托的概念

  1. 委托和类一样是一种用户自定义类型,它存储的就是一系列具有相同签名和返回类型的方法的地址,调用委托的时候,它所包含的所有方法都会被执行。

  2. 借用百度上的一句话概括:委托是一个类,它定义了方法的类型,使得可以将方法当作另一个方法的参数来进行传递,这种将方法动态地赋给参数的做法,

    可以避免在程序中大量使用If-Else(Switch)语句,同时使得程序具有更好的可扩展性

二、委托的声明

  与对应的方法具有相同的参数类型、参数个数、返回值。通俗来讲就是“函数的模板原型”。

三、委托的使用

  1. 用delegate声明一个委托
  2. 委托实例化
  3. 调用
      public class DelegateClass
    {
    public delegate void DelegateTest(int a, int b); //1、声明一个委托 public static void Test()
    {
    DelegateTest method = new DelegateTest(Plus); //2、实例化委托
    //DelegateTest method1 = Plus; //实例化委托的另一种等价写法
    method.Invoke(, ); //3、调用
    //method1(3, 4); //调用的另一种等价写法
    } private static void Plus(int a, int b)
    {
    Console.WriteLine("a={0} b={1}", a, b);
    }
    }

    四、委托的意义

      1、没有委托就没有异步

      2、解耦

      3、高效扩展

     public class CallStudent
    {
    //方法1
    public static void CallStudentA(string name)
    {
    Console.WriteLine("{0}", name);
    }
    //方法2
    public static void CallStudentB(string name)
    {
    Console.WriteLine("{0}", name);
    }
    //方法3
    public static void CallStudentC(string name)
    {
    Console.WriteLine("{0}", name);
    } //传值的方式,根据值来决定行为,所有的方法全部耦合在一起,
    //如果要增加方法则需要修改该方法,不便于方法的封装、扩展
    public static void CallStudentName(string name, StudentType type)
    {
    if (type == StudentType.A)
    {
    Console.WriteLine("{0}", name);
    }
    else if (type == StudentType.B)
    {
    Console.WriteLine("{0}", name);
    }
    else if (type == StudentType.C)
    {
    Console.WriteLine("{0}", name);
    }
    } //用委托的方式来实现传递方法,如果要增加方法,只需要重新增加一个方法就好
    public static void CallStudentName(string name, CallStudentHandler handler)
    {
    handler.Invoke(name);
    }
    } public delegate void CallStudentHandler(string name); public enum StudentType
    {
    A,
    B,
    C
    }
     static void Main(string[] args)
    {
    //用不同的值来区分不同的方法
    CallStudent.CallStudentName("Student A",StudentType.A );
    CallStudent.CallStudentName("Student B", StudentType.B);
    CallStudent.CallStudentName("Student C", StudentType.C );
    Console.WriteLine(); //用委托的方式传递多个方法
    CallStudentHandler handlerA = new CallStudentHandler(CallStudent.CallStudentA);
    CallStudent.CallStudentName("Student A", handlerA); CallStudentHandler handlerB = new CallStudentHandler(CallStudent.CallStudentB);
    CallStudent.CallStudentName("Student B", handlerB); CallStudentHandler handlerC = new CallStudentHandler(CallStudent.CallStudentC);
    CallStudent.CallStudentName("Student C", handlerC);
    Console.WriteLine(); //用匿名函数的方法替代上述写法
    CallStudentHandler handler1 = new CallStudentHandler(
    delegate(string name)
    {
    Console.WriteLine("{0}", name);
    }); //用匿名的方式把方法名给去掉
    handler1.Invoke("Student A"); //用lambda表达式的方式1 替代上述写法
    //Lambda表达式的本质就是一个匿名方法
    CallStudentHandler handler2= new CallStudentHandler(
    (string name)=>
    {
    Console.WriteLine("{0}", name);
    }); //用lambda表达式的方式把delegate换成=> 箭头左边是参数列表,右边是方法体
    handler2.Invoke("Student A"); //用lambda表达式的方式2
    CallStudentHandler handler3 = new CallStudentHandler(
    (name) =>
    {
    Console.WriteLine("{0}", name);
    }); //去掉参数类型
    handler3.Invoke("Student A"); //用lambda表达式的方式3
    CallStudentHandler handler4 =(name) =>
    {
    Console.WriteLine("{0}", name);
    }; //去掉 new CallStudentHandler
    handler4.Invoke("Student A"); //用lambda表达式的方式4
    CallStudentHandler handler5 = (name) => Console.WriteLine("{0}", name); //去掉{},适用于方法体只有一行
    //去掉{}后,如果方法体只有一行,带返回值的去掉return
    handler5.Invoke("Student A"); Console.ReadLine();
    }

    参考:https://www.cnblogs.com/goldendragon/p/9922592.html

浅谈C#委托的用法-delegate[转]的更多相关文章

  1. 浅谈C#委托的用法-delegate

    2018年11月7日     小雨 一.委托的概念 委托和类一样是一种用户自定义类型,它存储的就是一系列具有相同签名和返回类型的方法的地址,调用委托的时候,它所包含的所有方法都会被执行. 借用百度上的 ...

  2. 浅谈C#委托和事件

    委托给了C#操作函数的灵活性,我们可使用委托像操作变量一样来操作函数,其实这个功能并不是C#的首创,早在C++时代就有函数指针这一说法,而在我看来委托就是C#的函数指针,首先先简要的介绍一下委托的基本 ...

  3. 浅谈C#委托和事件【转】

    委托给了C#操作函数的灵活性,我们可使用委托像操作变量一样来操作函数,其实这个功能并不是C#的首创,早在C++时代就有函数指针这一说法,而在我看来委托就是C#的函数指针,首先先简要的介绍一下委托的基本 ...

  4. 浅谈C#委托和事件(转载)

    委托给了C#操作函数的灵活性,我们可使用委托像操作变量一样来操作函数,其实这个功能并不是C#的首创,早在C++时代就有函数指针这一说法,而在我看来委托就是C#的函数指针,首先先简要的介绍一下委托的基本 ...

  5. 浅谈 C#委托

    看了<CLR via C#>的17章委托后,为自己做一点浅显的总结,也分享给需要的人. .NET通过委托来提供一种回调函数机制,.NET委托提供了很多功能,例如确保回调方法是类型安全的(C ...

  6. 【Python学习笔记之二】浅谈Python的yield用法

    在上篇[Python学习笔记之一]Python关键字及其总结中我提到了yield,本篇文章我将会重点说明yield的用法 在介绍yield前有必要先说明下Python中的迭代器(iterator)和生 ...

  7. 浅谈final关键字的用法

    1.final变量: 常和static一起使用,修饰成员变量或者本地变量.修饰后为常量,不可以再次初始化(再次引用),例如public static final String SUCCESS= &qu ...

  8. 浅谈async函数await用法

    今天状态不太好,睡久了懵一天. 以前只是了解过async函数,并还没有很熟练的运用过,所以先开个坑吧,以后再结合实际来更新下,可能说的有些问题希望大家指出. async和await相信大家应该不陌生, ...

  9. 浅谈java中bigInteger用法

    1.赋值: BigInteger a=new BigInteger("1"); BigInteger b=BigInteger.valueOf(1); 2.运算: ① add(); ...

随机推荐

  1. centos6.x下使用xinetd管理rsync服务

    系统环境说明:centos6.x,centos7.x下rsync直接可由systemd管理(无需使用xinetd). [root@meinv01 ~]# rpm -qa|grep xinetd [ro ...

  2. 杭电-------2046骨牌铺方格(C语言写)

    #include<stdio.h> ] = { }; long long recrusion(int n) { || a[n]>) { return a[n]; } ) + recr ...

  3. CVE-2020-0668-Windows服务跟踪中的普通特权升级错误

    CVE-2020-0668-Windows服务跟踪中的普通特权升级错误 在这里中,我将讨论在Windows Service跟踪中发现的任意文件移动漏洞.从我的测试来看,它影响了从Vista到10的所有 ...

  4. python3-cookbook笔记:第八章 类与对象

    python3-cookbook中每个小节以问题.解决方案和讨论三个部分探讨了Python3在某类问题中的最优解决方式,或者说是探讨Python3本身的数据结构.函数.类等特性在某类问题上如何更好地使 ...

  5. 【转载】ibit-mybatis介绍

    原文链接:ibit-mybatis介绍 概述    ibit-mybatis是一个Mybatis的增强工具,在Mybatis的基础上增加了新的特性与功能,志在简化开发流程.提高开发效率. 特性 无侵入 ...

  6. Codeforces Round 450 D 隔板法+容斥

    题意: Count the number of distinct sequences a1, a2, ..., an (1 ≤ ai) consisting of positive integers ...

  7. IIS6的文件解析漏洞

    IIS6的默认配置漏洞会把cer.cdx.asa作为asp代码来解析 后缀解析漏洞 /test.asp;.jpg 或者/test.asp:.jpg(此处需抓包修改文件名) IIS6.0 都会把此类后缀 ...

  8. #《Essential C++》读书笔记# 第六章 以template进行编程

    练习题答案 练习6.1 试改写以下类,使它成为一个class template: class example { public: example(double min, double max); ex ...

  9. 多字节与Unicode

    编码知识 一.Unicode与多字节(ANSI ) (1)Windows中,Unicode也称为宽字节,多字节也称为窄字节; VS中默认使用Unicode编码,在项目属性>>配置属性> ...

  10. Travase Objects and four method of array

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...