C#中委托(下)

来源:转载

一、匿名方法


在使用委托的过程中不必定义仅由委托使用的方法,可以使用匿名方法。


声明:类似于方法的声明,不过参数列表前只有一个delegate关键字,没有其他修饰符、返回值类型和方法名。例如:delegate (int a){ }


下面给出示例:


// 声明了一个有两个 string类型的参数的委托,使用匿名方法替代了方法名实例化委托
Actiona = delegate (string str,string str1)
{
// 由于该类型委托没有返回值,所以不需要 return
};
// 声明了一个 string类型的参数和 string类型返回值的委托,使用匿名方法替代了方法名实例化委托
Funcb = delegate (string str)
{
return "匿名方法";
};
注意:


1、匿名方法没有方法名和返回值声明,使用匿名方法时,要根据委托类型看是否需要返回值;


2、匿名方法可以减少代码的使用,但是并没有加快代码的执行速度,编译器仍定义了一个自动指定名称的方法。


二、lambda 表达式


可以使用lambda表达式来代替匿名方法的使用,他比匿名方法更简单。例如:a =>{ }


lambda 表达式与 匿名方法的区别


1、lambda 表达式没有 delegate 关键字,使用 => 来指向方法体,当只有一个参数的时候可以不使用括号;


2、lambda 表达式 的参数可以不用声明类型。


下面给出示例:


//匿名方法
Funcc = delegate (string str)
{
return "匿名方法";
};
//lambda 表达式
Funcd =str =>
{
return "匿名方法";
};
//匿名方法1
Funcc1 = delegate (string a,string b)
{
return int.Parse(a+b);
};
//lambda 表达式1
Funcd1 =(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 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;
}
}



分享给朋友:
您可能感兴趣的文章:
随机阅读: