1.匿名方法的概念:一个方法没有具体的名称,而只有关键字delegate、方法参数、方法体、这种方法是匿名方法。

匿名方法的好处:将具体方法和委托直接关联在一起,如果我们基于委托只需要一个方法的时候,匿名方法肯定显得简单。

2.Lambda表达式:在C#3.0出现的。使用这种表达的可以更简练的编写代码块。

CalculatorDelegate cal3 = (int a, int b) => { return a + b; };
CalculatorDelegate cal4 = (a, b) => a - b;

【1】Lambad的参数类型可以是明确类型,也可以是推断类型。

【2】如果是推断类型,则参数类型可以由编译根据上下文自动推断出来

【3】运算符=>读作goes to,运算符左边输入参数,右边是表达式或者代码块。

【4】表达式有两种方式:

(input args)=>表达式
(input args)=>{ 语句1;语句2;语句3....}

【5】Lambda表达式和匿名方法的比较:

第一,Lambda本身就是匿名方法。

第二,Lambda表达式不允许指明参数类型,但是匿名方法必须要明确。

第三,Lambda表达式允许单一的表达式或者多条语句组成,而匿名方法不允许单一表达式。

3.自定义泛型委托

【1】为什么要用泛型委托?普通委托在数据类型上的限定是非常严格的,有时候我们的需求变化,可能适应不了,这时候考虑的就是泛型委托。

【2】泛型委托定义:本质上和泛型方法是非常类似的,泛型委托关联的时候可以是具体方法,匿名方法或者Lambda表达式。

【3】试想如果我们有五个参数、六个参数甚至更多的参数,按照目前的思路我们不得不定义很多种这种方法,很麻烦,这时候就要考虑系统泛型委托,所谓系统泛型委托,就是C#.NET为

我们定义好的泛型委托,可以直接拿来用。

4.自定义泛型委托:主要介绍两种,一种是有返回值的Func<T>和一种是没有返回值的Action<T>

Action<T>在多线程中用的非常多。

Func<T>在扩展方法中用的非常多。

结论:泛型委托作为方法参数,实际上传递的是一个具体方法或一个Lambda表达式! (多态一种表现)

a.自定义普通委托和Lambda表达式:

  1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4. using System.Text;
  5. using System.Threading.Tasks;
  6.  
  7. namespace AdVancedTest
  8. {
  9. public class LambdaDemo
  10. {
  11. public static void Test()
  12. {
  13. //委托关联独立的方法
  14. CalCulatorDelegate MyCal1 = Add;
  15. int result1 = MyCal1(10, 20);
  16. Console.WriteLine("委托关联独立的方法来计算a+b=" + result1);
  17. //委托关联匿名方法
  18. CalCulatorDelegate MyCal2 = delegate (int a, int b) { return a + b; };
  19. int result2 = MyCal2(30, 30);
  20. Console.WriteLine("通过匿名方法来计算a+b" + result2);
  21. //将匿名方法简化为Lambda表达式:goes to 参数列表(参数1,参数2....)=>{函数体}
  22. CalCulatorDelegate MyCal3 = (int a, int b) =>
  23. {
  24. Console.WriteLine(100);
  25. return a + b;
  26. };
  27.  
  28. //进一步简化:假如方法中只有一行代码,可以省略{}
  29. CalCulatorDelegate MyCal4 = (a, b) => a + b;
  30. int result4 = MyCal4(40,50);
  31. Console.WriteLine("简化Lambda表达式计算a+b="+result4);
  32. SayHelloDelegate sayHello = (msg) => msg;
  33. string result5= sayHello("Hello World");
  34. Console.WriteLine("SayHello委托:"+result5);
  35.  
  36. //Lambda表达式允许不指明参数类型,但是匿名方法必须要明确。
  37. CalCulatorDelegate myCal5 = (a, b) => { return a + b; };
  38. myCal5(10,12);
  39. }
  40. private static int Add(int a, int b)
  41. {
  42. return a + b;
  43. }
  44. }
  45. //【1】声明委托
  46. public delegate int CalCulatorDelegate(int a, int b);
  47. public delegate string SayHelloDelegate(string msg);
  48. }

输出结果为:

  1. 委托关联独立的方法来计算a+b=30
  2. 通过匿名方法来计算a+b60
  3. 简化Lambda表达式计算a+b=90
  4. SayHello委托:Hello World

b.自定义泛型委托

  1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4. using System.Text;
  5. using System.Threading.Tasks;
  6.  
  7. namespace AdVancedTest
  8. {
  9. public class GenericClass
  10. {
  11. public static void Test()
  12. {
  13. //范型委托关联具体方法,基于泛型委托,
  14. MyGenericDelegate<int> myGenericDelegate1 = Add;
  15. int result1 = myGenericDelegate1(10, 30);
  16. Console.WriteLine("范型委托关联具体方法:" + result1);
  17.  
  18. //泛型委托关联元祖方法
  19. MyDelegate<string, int, int> myDelegate1 = Mymethod;
  20. var result2= myDelegate1();
  21.  
  22. //使用元组的默认参数名
  23. var result4 = Mymethod();
  24. Console.WriteLine(result4.str+"\t"+result4.a+"\t"+result4.b);
  25. Console.WriteLine(result2.Item1+result2.Item2+result2.Item3);
  26.  
  27. //使用元组的自定义参数名
  28. MyDelegate<string ,int ,int > myDelegate2 = Mymethod;
  29. var result3 = myDelegate2();
  30. Console.WriteLine(result3);
  31.  
  32. //使用泛型委托:匿名方法
  33. MyGenericDelegate<int> myGenericDelegate4 = delegate(int a,int b){ return a + b; };
  34. MyGenericDelegate<double> myGenericDelegate5 = delegate (double a, double b) { return a + b; };
  35.  
  36. int result5=myGenericDelegate4(20,30);
  37. Console.WriteLine(result5);
  38. double result6 = myGenericDelegate5(20,30);
  39. Console.WriteLine(result6);
  40.  
  41. //使用泛型委托:Lambaa表达式
  42. MyGenericDelegate<int> myGenericDelegate6 = (a, b) => a + b;
  43. int result7= myGenericDelegate6(20, 30);
  44. Console.WriteLine(result7);
  45.  
  46. MyGenericDelegate<double> myGenericDelegate7 = (a, b) => a + b;
  47. double result8= myGenericDelegate7(20, 30);
  48. Console.WriteLine(result8);
  49. }
  50. private static int Add(int a, int b)
  51. {
  52. return a + b;
  53. }
  54. private static int Sub(int a, int b)
  55. {
  56. return a - b;
  57. }
  58. //元组C#7.0新操作:元組
  59. private static (string str, int a, int b) Mymethod()
  60. {
  61. return ("C#.NET",4, 5);
  62. }
  63.  
  64. }
  65. //定义泛型委托
  66. public delegate T MyGenericDelegate<T>(T param1, T param2);
  67.  
  68. public delegate (T1, T2, T3) MyDelegate<T1, T2, T3>();
  69.  
  70. }

输出结果

  1. 范型委托关联具体方法:40
  2. C#.NET 4 5
  3. C#.NET45
  4. (C#.NET, 4, 5)
  5. 50
  6. 50
  7. 50
  8. 50

c.系统泛型委托

  1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4. using System.Text;
  5. using System.Threading.Tasks;
  6.  
  7. namespace AdVancedTest
  8. {
  9. public class FuncDemo
  10. {
  11. /// <summary>
  12. /// Func的基本使用: 在扩展方法中用的非常多,最后一个表示返回自类型
  13. /// </summary>
  14. /// <returns></returns>
  15. public static int Test1()
  16. {
  17. Func<int, int, int> func1 = Add1;//输入,输入,输出
  18. int result1 = func1(10, 20);
  19. //直接使用Lambad表达式,第四个参数表示返回值为string类型
  20. Func<int, int, int, string> fun3 = (a,b,c) => { return (a + b+c).ToString(); };
  21. Func<int, int, int> func2 = (a, b) => a + b;
  22. int result2 = func2(40,40);
  23. string result3 = fun3(40,40,60);
  24. Console.WriteLine("------------------------------------------------------------------------");
  25. Console.WriteLine(result1);//30
  26. Console.WriteLine(result2);//80
  27. Console.WriteLine(result3);//140
  28. return result1;
  29. }
  30. private static int Add1(int a,int b)
  31. {
  32. return a + b;
  33. }
  34. private static int Mul1(int a, int b)
  35. {
  36. return a * b;
  37. }
  38. /// <summary>
  39. /// Func委托的重要使用
  40. /// </summary>
  41. /// <returns></returns>
  42. ///
  43. //问题:给定一个数组 { 10, 9, 8, 7, 6, 5, 4, 3, 2 },从数组中指定位置抽取3个数,求和、求积
  44. public int Test2()
  45. {
  46. //普通方法求和求积
  47. int[] nums = new int[] { 10, 9, 8, 7, 6, 5, 4, 3, 2 };
  48. Sum(nums,0,2);
  49.  
  50. return Mul(nums,0,2);
  51. }
  52.  
  53. private int Sum(int[]nums,int From,int To)
  54. {
  55. int sum = 0;
  56. for (int i=From;i<To;i++)
  57. {
  58. sum += nums[i];
  59. }
  60. return sum;
  61. }
  62.  
  63. private int Mul(int[] nums, int From, int To)
  64. {
  65. int mul = 1;
  66. for (int i = From; i < To; i++)
  67. {
  68. mul *= nums[i];
  69. }
  70. return mul;
  71. }
  72.  
  73. //把Func委托做为参数传递实际传递的是一个具体的方法或者一个Lambda表达式:也是多态的一种表现
  74. private static int Operation(Func<int,int,int> method,int[]nums,int from,int to)
  75. {
  76. int result = nums[from];
  77. for (int i=from+1;i<to;i++)
  78. {
  79. //method(result,nums[i]):方法的返回值
  80. result = method(result, nums[i]);
  81. }
  82. return result;
  83. }
  84.  
  85. public static void Test3 ()
  86. {
  87. int[] nums = new int [] { 10, 9, 8, 7, 6, 5, 4, 3, 2 };
  88. int result1= Operation(Add1,nums,0,3);//计算加运算
  89. int result2 = Operation(Mul1,nums,0,3);//计算乘法运算
  90. Console.WriteLine("返回10+9+8="+result1);
  91. Console.WriteLine("返回10*9*8="+result2);
  92. }
  93. }
  94. }

d.Func<T>委托

  1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4. using System.Text;
  5. using System.Threading.Tasks;
  6.  
  7. namespace OperationXml
  8. {
  9. public class A
  10. {
  11. bool bDeviceConnected = false;
  12. public void test()
  13. {
  14. Variable.val = new VarRef<object>(() => bDeviceConnected, val => { bDeviceConnected = (bool)val; });
  15. Console.WriteLine(bDeviceConnected);
  16. Variable.val.Value = true;
  17. Console.WriteLine(bDeviceConnected);
  18. }
  19. }
  20. public class VarRef<T>
  21. {
  22. public Func<T> _get;
  23. public Action<T> _set;
  24.  
  25. /// <summary>
  26. /// 传递一个系统泛型委托,实际传递的是一个泛型方法
  27. /// @get:传递() => bDeviceConnected,获取bDeviceConnected
  28. /// @set:设置bDeviceConnected的值
  29. /// </summary>
  30. public VarRef(Func<T> @get, Action<T> @set)
  31. {
  32. _get = @get;
  33. _set = @set;
  34. }
  35.  
  36. /// <summary>
  37. /// 属性,对bDeviceConnected进行读和写
  38. /// </summary>
  39. public T Value
  40. {
  41. get { return _get(); }
  42. set { _set(value); }
  43. }
  44.  
  45. }
  46. public class Variable
  47. {
  48. public static VarRef<object> val;
  49. }
  50. }

输出结果

  1. False
  2. True

匿名方法、Lambda表达和自定义泛型委托以及Func、Action系统泛型委托的更多相关文章

  1. C#委托总结-匿名方法&Lambda表达式

    1,匿名方法 匿名方法可以在声明委托变量时初始化表达式,语法如下 之前写过这么一段代码: delegate void MyDel(string value); class Program { void ...

  2. C# delegate event func action 匿名方法 lambda表达式

    delegate event action func 匿名方法 lambda表达式 delegate类似c++的函数指针,但是是类型安全的,可以指向多个函数, public delegate void ...

  3. 委托-异步调用-泛型委托-匿名方法-Lambda表达式-事件【转】

    1. 委托 From: http://www.cnblogs.com/daxnet/archive/2008/11/08/1687014.html 类是对象的抽象,而委托则可以看成是函数的抽象.一个委 ...

  4. 委托delegate 泛型委托action<> 返回值泛型委托Func<> 匿名方法 lambda表达式 的理解

    1.使用简单委托 namespace 简单委托 { class Program { //委托方法签名 delegate void MyBookDel(int a); //定义委托 static MyB ...

  5. C#多线程+委托+匿名方法+Lambda表达式

    线程 下面是百度写的: 定义英文:Thread每个正在系统上运行的程序都是一个进程.每个进程包含一到多个线程.进程也可能是整个程序或者是部分程序的动态执行.线程是一组指令的集合,或者是程序的特殊段,它 ...

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

    概念了解: 1.什么是匿名委托(匿名方法的简单介绍.为什么要用匿名方法) 2.匿名方法的[拉姆达表达式]方法定义 3.匿名方法的调用(匿名方法的参数传递.使用过程中需要注意什么) 什么是匿名方法? 匿 ...

  7. c# 中的委托以及匿名方法lambda

    1.委托的定义internal delegate int MyAddFunDe(int a,int b)2.匿名方法1)MyAddFunDe fun = delegate(int a,int b){  ...

  8. 函数~匿名方法~lambda的逐渐过渡思想

    前提:基于委托实现 (1)使用函数名称 delegate void Printer(string s);//(1)申明委托 static void Main(string[] args) { //(3 ...

  9. 匿名函数 =匿名方法+ lambda 表达式

    匿名函数的定义和用途 匿名函数是一个"内联"语句或表达式,可在需要委托类型的任何地方使用. 可以使用匿名函数来初始化命名委托[无需取名字的委托],或传递命名委托(而不是命名委托类型 ...

随机推荐

  1. Html飞机大战(六):移动飞机

    好家伙,这篇移动主角   我们先来看看一个好东西, addEventListener() 方法 (他真的很好用)   我们直译一下,就叫他添加事件监听器方法   而可监听的对象就有很多啦 我们来了解一 ...

  2. Springboot连接数据库 (解决报错)

    好家伙,来解决报错 1.新建项目时, 将SQL的" Spring Date 'jdbc' "点上 2.使用idea快速创建springboot项目时会出现连接不到服务器的情况 这里 ...

  3. 基于Vue的前端UI组件库的比对和选型

    大家好,我是张飞洪,感谢您的阅读,我会不定期和你分享学习心得,希望我的文章能成为你成长路上的垫脚石,让我们一起精进. 由于录制视频的需要,要做前端UI组件库的选型.平时国内外也见了不少基于Vue的UI ...

  4. 安装docker-compose--翻译

    Install Docker Compose 译文 安装 Docker Compose 你可以在macOS.Windows.64-bit Linux上运行 Compose 前提条件 Docker Co ...

  5. 选择排序C语言版本

    算法思路,从头至尾扫描序列. 首先从第二个到最后,找出最小的一个元素,和第一个元素交换: 接着从第三个到最后,后面找出最小的一个元素,和第二个元素交换: 依次类推最终得到一个有序序列. void Se ...

  6. C语言的几个入门关于函数调用练习

    1.找素数(素数:除了1和本身之外不能被任何整数整除的的数)(被某数整除=除以某数是整数) 问题:输出2到200(包括2和200)的使有素数,从小到大排序. 思路:检查所有比i小的数,取余. 涉及的知 ...

  7. day38-IO流05

    JavaIO流05 4.常用的类04 4.4节点流和处理流03 4.4.8打印流-PrintStream和PrintWriter 打印流只有输出流,没有输入流 1.简单介绍及应用 PrintStrea ...

  8. Kubernetes(K8S)特性有哪些?

    Kubernetes简介 Kubernetes是一个开源的,用于管理云平台中做个主机上的容器化的应用,Kubernetes的目标是让部署容器化的应用简单且高效,Kubernetes提供了应用部署,规划 ...

  9. MongoDB 单实例节点主机的用户和权限一般操作步骤

    步骤总结: 1.先正常启动 2.创建用户,创建数据库病授权用户 3.关闭程序,开启安全,然后启动 4.使用账号和密码连接 按未开启认证的方式(配置文件中没开启安全选项并且启动命令中不添加 --auth ...

  10. 15_abstract,static,final

    一. abstract 1. 抽象类 被abstract修饰的类,称为抽象类 抽象类意为不够完整的类.不够具体的类 抽象类对象无法独立存在,即不能new对象,但可以声明引用 作用: 可被子类继承,提供 ...