随着.net3.5时代的到来,我们所学习的编程寓言各种新特性也接着到来,那么Lambda表达式带给我们的是什么呢?下面徐州北大青鸟技术老师给我们做了系统的讲解和举例介绍。
说lambda肯定离不开匿名方法,说匿名方法肯定离不开委托,其实,你可以把这三个东西看作是一个事物的不同发展阶段,他们也标志着.net framework的发展史:
.net frameworks 1.x 委托
.net frameworks 2.x 匿名方法来实现委托
.net frameworks 3.x lambda表达式来实现委托
委托,delegate你不要简单的说,“把方法当方法的参数传递给一个方法”,说实话,过去很长一段时间我也是局限在这个概念上的,但真的静下来想想,可能并非这样,委托做为一种思想出现在了.net世界里,从1.x就开始了它的征途,到2.x委托的实例创建上有了质的突破,可能体现在写法简洁上(匿名方法),到了3.x配合lambda表达式,使人们渐渐把委托给忘记了,其实在lambda表达式里,你关心的可能不在是委托,而是一个业务的语义问题,即它更加人性化了。如select选择,where条件,orderby排序等。
下面再带大家看一个1.x到3.x委托实例的演化
.net 1.x时代
1 /// <summary>
2 /// 输出字符串,返回为整数
3 /// </summary>
4 /// <param name="str"></param>
5 /// <returns></returns>
6 public delegate int Count(string str);
7 /// <summary>
8 /// 求字符长度的方法
9 /// </summary>
10 /// <param name="str"></param>
11 /// <returns></returns>
12 public static int StrLength(string str) { return str.Length; }
调用时,需要实例化委托
1 Count a = new Count(StrLength);
2 a("abc");
.net 2.x时代,出现了匿名方法,它省略了实名方法的创建
1 Count anonymous = delegate(string str2)
2 {
3 return str2.Length;
4 };
5 Console.WriteLine(anonymous("123"));
使用匿名方法,确实优化了不少,但好像还是少了点什么,感觉有点别扭,可以是delegate关键惹的祸吧
,在进入.net3.5 时代后,引入了lambda表达式,看看这种很炫的技术吧
1 Count lambda = i =>
2 {
3 return i.Length;
4 };
代码又精简了,去掉了delegate关键字,实现上这种写法还不是正规的表达式写法,代码可以代进行精减
1 Count lambda2 = i => i.Length;
恩,这回应该是我们所需要的了,事实上,lambda表达式的这种特性叫“类型推演”,它可以推断出你的类型是什么,这个特性被广泛的应用在了LINQ上,而向我之前介绍过的Func也是微软为我们封装好的委托,用lambda来实现它,很巧妙。
Func<int, int> chengfang = (int cheng) => cheng * cheng;
当然,在lambda表达式美丽的背后,也有一些缺点:如性能有所降低,当然我是我们可以接受的。
在感受.net语言魅力之后是不是觉得很有意思呢?想了解更多关于技术方面的问题欢迎来到徐州北大青鸟!
