一、匿名方法
在使用委托的过程中不必定义仅由委托使用的方法,可以使用匿名方法。
声明:类似于方法的声明,不过参数列表前只有一个delegate关键字,没有其他修饰符、返回值类型和方法名。例如:delegate (int a){ }
下面给出示例:
// 声明了一个有两个 string类型的参数的委托,使用匿名方法替代了方法名实例化委托
Action<string,string> a = delegate (string str,string str1)
{
// 由于该类型委托没有返回值,所以不需要 return
};
// 声明了一个 string类型的参数和 string类型返回值的委托,使用匿名方法替代了方法名实例化委托
Func<string,string> b = delegate (string str)
{
return "匿名方法";
};
注意:
1、匿名方法没有方法名和返回值声明,使用匿名方法时,要根据委托类型看是否需要返回值;
2、匿名方法可以减少代码的使用,但是并没有加快代码的执行速度,编译器仍定义了一个自动指定名称的方法。
二、lambda 表达式
可以使用lambda表达式来代替匿名方法的使用,他比匿名方法更简单。例如:a =>{ }
lambda 表达式与 匿名方法的区别
1、lambda 表达式没有 delegate 关键字,使用 => 来指向方法体,当只有一个参数的时候可以不使用括号;
2、lambda 表达式 的参数可以不用声明类型。
下面给出示例:
//匿名方法
Func<string,string> c = delegate (string str)
{
return "匿名方法";
};
//lambda 表达式
Func<string,string> d = str =>
{
return "匿名方法";
};
//匿名方法1
Func<string,string,int> c1 = delegate (string a,string b)
{
return int.Parse(a+b);
};
//lambda 表达式1
Func<string,string,int> d1 = (a,b) =>
{
return int.Parse(a+b);
};
三、闭包
闭包的定义:通过 lambda 表达式可以访问 lambda 表达式外部的变量。
注意:如果 lambda 表达式内部用到了外部的变量,当外部变量的值改变时,lambda 表达式里的值也会相应改变。
原理:在编译器编译 lambda 表达式的时候会创建一个匿名类,他有一个构造函数来访问外部的变量,还有一个匿名方法,其返回值,参数,实现由 lambda 表达式定义。当使用 lambda 表达式实例化的委托时,会创建该匿名类的一个实例并使用外部的变量来初始化,并访问该类的匿名方法。
下面给出示例:
public class MyClass
{
// 声明一个字段 a
static int a = 1;
// 声明一个委托使用 lambda 表达式实例化,返回值是参数与 a 的和
Func<int,int> dele = para =>
{
return para + a;
};
}
// 这里是匿名类(名字是随便定义的)
public class VarClass
{
// 字段
int someValue;
// 自定义构造函数,参数的个数与类型与委托定义的参数个数和类型一致
public VarClass(int someValue)
{
this.someValue = someValue;
}
// 匿名方法
public int VarMethod(int para)
{
return para + this.someValue;
}
}