首页 » .NET » C#中委托(下)

C#中委托(下)

原文 http://blog.csdn.net/cloproad/article/details/79175791

2018-01-27 02:00:24阅读(407)

一、匿名方法

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

声明:类似于方法的声明,不过参数列表前只有一个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;
   }
}



最新发布

CentOS专题

关于本站

5ibc.net旗下博客站精品博文小部分原创、大部分从互联网收集整理。尊重作者版权、传播精品博文,让更多编程爱好者知晓!

小提示

按 Ctrl+D 键,
把本文加入收藏夹