前言

最近在阅读某开源框架源码的时候,发现作者在其中运用了很多 Action委托 和 Func委托 ,虽然我之前在项目中也有一些对委托的实操,但还是免不了长时间的不用,当初消化的一些委托基础都遗忘了。。。索性,趁热打铁,借助这次分享的机会,也帮自己重新巩固下.Net中关于委托的一些基础用法。

直奔主题

从.Net Framework1.0开始就为我们提供了委托的功能使用。那个时候.Net内置委托Action和Func还没有问世,那么,我们先来看看1.0版本时候的委托。委托从字面上来理解就是“帮别人干活”,具体干活的内容交给了“方法”,所以通俗点理解—— 委托通常被用来表示对一个方法的调用 。具体怎么用,我们接着往下看。

声明委托

格式:

  • 用关键字“ delegate ”修饰委托
  • 委托的 返回值 和 参数 要和被委托的方法 保持一致

形如:

/// <summary>
  /// 声明委托
  /// </summary>
  public delegate void BuyGoodsDelegate(string Name);
  /// <summary>
  /// 委托的方法
  /// </summary>
  public void BuyGoods(string Name)
  {
   Console.WriteLine($"小明让我去买{Name}");
  }

委托和方法关联

在声明了委托和定义好方法之后,我们需要将委托和方法进行关联,这样委托才能知道自己要调用的是哪个方法。

//委托和方法关联
BuyGoodsDelegate buyGoods = new BuyGoodsDelegate(BuyGoods);

委托调用方法

将委托和方法进行关联之后,我们就可以直接操作委托实例来进行方法的调用,调用方式和直接调用方法差不多。

//调用方式1
buyGoods("鞋子");
//调用方式2
buyGoods.Invoke("衣服");

4.效果

Asp.Net中的Action和Func委托实现

有了上面的使用之后,我们会发现委托基本都是根据具体方法来声明的,如果不同的方法有3个,4个或者更多的参数,显然,我们需要分别声明不同参数个数的委托,不经意间多了一道“声明委托”的门槛。于是,在.Net Framework3.5版本之后发布了.Net自带的内置委托Action和Func。我们 不用再做“声明委托”的工作 ,直接可以使用。

Action委托

Action委托 提供无参数、有参数方法,但不提供返回类型 ,具有Action、Action<T>、Action<T1,T2>、Action<T1,T2,T3>……Action<T1,……T16>多达16个参数的形式,其中传入参数均采用泛型T,涵盖了几乎所有可能存在的无返回值的委托类型。

Func委托

Func委托 提供无参数、有参数方法,同时提供返回类型 ,具有Func<TResult>、Func<T,Tresult>……Func<T1,T2,T3……,Tresult>17种类型重载,T1……T16为参数,Tresult为返回类型。

前面我们说,Action委托和Func委托不用再声明,便可直接使用,除了这一点,它们还支持 匿名函数、lamda表达式形式 。

普通函数调用

其中,Student是入参类型,string为返回参数类型

//委托和方法关联
  Func<Student, string> funcNew = FuncTestDelegate;

  /// <summary>
  /// string返回类型方法
  /// </summary>
  /// <param name="student"></param>
  /// <returns></returns>
  public string FuncTestDelegate(Student student)
  {
   return student.StudentName;
  }

我们可以看到Func委托使用的时候,不用声明便可以直接使用。

匿名函数

匿名函数需要用关键字“delegate”声明

//Func 匿名函数 
   Func<int,int,string> func3 = delegate(int num1,int num2)
   {
    return $"Func:总和:{num1+ num2}";
   };
   //调用
   var result = func3(10, 20);

lamda表达式

//Func lamda表达式 无参数
   Func<string> func1 = () =>
   {
    return "Func:你好";
   };
   var result = func1();

   //Func lamda表达式 有参数
   string aa = "ABC";
   string bb = "DEF";
   Func<string, string, string> func2 = (p1, p2) =>
   {
    return $"Func:{p1},你好{p2}";
   };
   result = func2(aa, bb);

Action委托实例

Action委托和Func委托的 唯一区别就是没有返回类型 ,其他用法都一样,当不需要返回类型的时候,直接用Action委托。

//Action lamda表达式
   Action<string, string> action = (p1, p2) =>
   {
    Console.Write($"Action:{p1},你好{p2}");
   };
   action("ABC", "DEF");

小结

本文中,主要介绍了自定义委托以及.Net内置委托Action和Func的基础用法,以及他们之间的一些区别。总体上来看还是比较简单的,稍微动动手自己写一遍就能感受到其中的魅力。不多说了,希望充足自己的同时也能给更多的小伙伴的生活中加点盐。

广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!

RTX 5090要首发 性能要翻倍!三星展示GDDR7显存

三星在GTC上展示了专为下一代游戏GPU设计的GDDR7内存。

首次推出的GDDR7内存模块密度为16GB,每个模块容量为2GB。其速度预设为32 Gbps(PAM3),但也可以降至28 Gbps,以提高产量和初始阶段的整体性能和成本效益。

据三星表示,GDDR7内存的能效将提高20%,同时工作电压仅为1.1V,低于标准的1.2V。通过采用更新的封装材料和优化的电路设计,使得在高速运行时的发热量降低,GDDR7的热阻比GDDR6降低了70%。