• c#委托的三种实现方式


     委托是实质一个类,主要目的是将方法当作参数进行传递。

    委托是.NET编程的精髓之一,在日常编程中经常用到,在C#中实现委托主要有Func、Action、delegate三种方式,本节主要就这三种委托的用法通过实例展开讲解。

    Func用法解析

         【Func】:Func是带返回值的委托:

    原型函数如下(以下展示的是有两个参数的情况):

    public delegate TResult Func<in T1, in T2, out TResult>(T1 arg1, T2 arg2);

    用法举例1: 定义方法StringAddA

    public int StringAddA(string a, string b)        {            return int.Parse(a) + int.Parse(b);        }

    定义委托func,然后把方法StringAddA委托给它,接下来执行委托并获取结果,注意:

    Func<string, string, int> func = StringAddA;Func<string, string, int> func = new Func<string, string, int>(StringAddA);的简写
      Func<string, string, int> func = StringAddA;//简写            var result = func.Invoke("3", "5");//可以简化为func("3", "5")            sw.AppendLine($"【func用法1】func返回结果是:{result}");

    这里的执行结果是: 【func用法1】func返回结果是:8

    用法举例2: 

    lamda表达式简化写法,通过+=注册实现多播委托​​​​​​​

      func += (a, b) =>            {                return int.Parse(a) - int.Parse(b);            };            sw.AppendLine($"【func用法2】func返回结果是:{func("3", "5")}");

    这里的执行结果是: 【func用法1】func返回结果是:-2

    注意 += 可以注册多个委托,委托执行后会按顺序执行方法.

    Action用法解析

         【Action】:Action是无返回值的委托:

    原型函数如下(以下展示的是有两个参数的情况):

    public delegate void Action<in T1, in T2>(T1 arg1, T2 arg2);

    用法举例:

    先定义方法:StringAddB​​​​​​​

        public void StringAddB(string a, string b)        {            sw.AppendLine($"【Action用法】Action执行结果:{(int.Parse(a) + int.Parse(b))}");        }

    实例如下:​​​​​​​

     Action<string, string> action = StringAddB;//简写            IAsyncResult asyncResult = action.BeginInvoke("3", "5", null, null);//action("3", "5"),BeginInvoke异步执行,即:开启新现成处理StringAddB            action.EndInvoke(asyncResult);//阻塞委托,直到执行完成            if (asyncResult.IsCompleted)            {                sw.AppendLine($"【Action用法】当前异步委托线程已执行完成");            }

    这里BeginInvoke是异步委托,即新开线程去处理,我们的窗体线程在1号线程,这里我们可以在StringAddB里面打印线程id号

    sw.AppendLine($"【Action用法】Action执行线程id:{Thread.CurrentThread.ManagedThreadId}");

    运行结果:

    【Action用法】Action执行线程id:3

    这里的EndInvoke是阻塞委托,直到执行完成,当然我们这里也可以用同步的Invoke去执行,甚至Invoke都可以简写去掉,直接写成action("3", "5")

    delegate用法解析

        【delegate】:delegate是可以有返回值也可以没返回值的委托:

    使用前需要先声明:

     delegate int DelegateM(string a, string b);//声明,可以有返回值也可以没有

    用法举例:​​​​​​​

       //delegate用法            //DelegateM delegateM = new DelegateM(p.StringAddA);            DelegateM delegateM = StringAddA;//简写            sw.AppendLine($"【delegate用法】delegate返回结果是:{delegateM("3", "5")}");

    以上就是三种委托的区别和用法讲解,那使用委托最大的优势是什么:

    可以将方法当作参数去传递,用法举例如下:

       Test(func, action);//将方法委托后转化为参数进行传递

    定义方法​​​​​​​

         public void Test(Func<string, string, int> f, Action<string, string> a)        {            a.Invoke(f.Invoke("3", "5").ToString(), "5");        }

    都看到这了,如果您感觉我推荐的内容对您有帮助,希望您能伸出援手,给我打赏一元请我喝瓶水;您的支持将是我在继续分享传作路上的无限动力。如果您囊肿羞涩也没有关系,希望您多写评论予以支持,山高水常,来日在见。

  • 相关阅读:
    迷宫问题(DFS,BFS)
    Python---练习:while循环案例:猜数字
    正则表达式
    Homomorphic Evaluation of the AES Circuit:解读
    Leetcode92. 反转链表 II
    前端安全方面
    Rust 解引用
    基于JAVA抑抑心理交流平台计算机毕业设计源码+系统+数据库+lw文档+部署
    CSDN流量卷领取和使用保姆级教程——流量卷,恭喜获得每日任务奖励【1500曝光】可获得新增曝光,阅读转化,点赞转化,新增关注-流量卷,流量卷,流量卷
    148. 排序链表 ●●
  • 原文地址:https://blog.csdn.net/A_nanda/article/details/136315542