在最近比较新的项目中,已经开始在大量使用LINQtoSQL了。LINQ旨在成为,在.NET中,访问不同类型数据源的统一标准。我个人不赞同,也不希望如此。有些时候,一个庞大的杀毒软件,还不如一个几十K的专杀工具来的轻便。当然,LINQ的优势,在于对结构化数据的处理.
于是就有了:
LINQ to Object
LINQ to XML
LINQ to SQL
这些目标数据源共同特性之一----较强的结构性。
........从LINQ追溯Lambda
- //LINQtoObject
- IEnumerablefilteredResult=fromcustomerincustomers
- wherecustomer.FirstName=="Donna"
- selectcustomer;
上面是一个很简单的LINQtoObject.有的人就会说,这和我用一个foreach的工作量差不多啊!如果你这样想,就太小瞧他了.配合join..onorderbyletnestingwhere,效率的提高,那不是一点点了哈.:)
具体的例子,不需要给出。点到即可。
LINQ中的filter,是从LambdaExpression演化而来.
上面的例子稍作变化,就可以看到我们亲切的Lambda了.
- Lambda在LINQ
- //StatementLambdasinLINQ
- IEnumerablefilteredResult=(fromcustomerincustomers
- selectcustomer).Where(c=>c.FirstName.Equals("Donna"));
........从Lambda追溯Delegate
LambdaExpression是C#3.0中出现的神奇之物,它由C#2.0中的匿名函数演化而来。同时,也将匿名函数的作用,发挥到了***.有了它,我们甚至都可以不用指定参数的类型。
- BubbleSort(items,
- (firstItem,secondItem)=>
- {
- returnfirstItem});
回想一下,在C#2.0中,我们是如何使用匿名函数的:
- BubbleSort(items,
- delegate(intfirstItem,intsecondItem)
- {
- returnfirstItem});
至于C#1.1中的代理,我不想回忆了,太痛苦:<
不仅方法不能省,还要使用被代理函数的作为参数,构造代理对象.
【编辑推荐】