.NETLINQ查询语法与方法语法

合集下载
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

.NETLINQ查询语法与⽅法语法
LINQ 查询语法与⽅法语法
通过使⽤ C# 3.0 中引⼊的声明性查询语法,介绍性 LINQ ⽂档中的多数查询都被编写为查询表达式。

但是,.NET 公共语⾔运⾏时 (CLR) 本⾝并不具有查询语法的概念。

因此,在编译时,查询表达式会转换为 CLR 确实了解的内容:⽅法调⽤。

这些⽅法称为“标准查询运算符”,它们具有如下名称:Where、Select、GroupBy、Join、Max、Average 等。

可以通过使⽤⽅法语法⽽⾮查询语法来直接调⽤这些⽅法。

通常我们建议使⽤查询语法,因为它通常更简单、更易读;但是⽅法语法和查询语法之间并⽆语义上的区别。

此外,⼀些查询(如检索匹配指定条件的元素数的那些查询或检索具有源序列中的最⼤值的元素的查询)只能表⽰为⽅法调⽤。

System.Linq 命名空间中的标准查询运算符的参考⽂档通常使⽤⽅法语法。

因此,即使在开始编写 LINQ 查询时,熟悉如何在查询和查询表达式本⾝中使⽤⽅法语法也⾮常有⽤。

标准查询运算符扩展⽅法
class QueryVMethodSyntax
{
static void Main()
{
int[] numbers = { 5, 10, 8, 3, 6, 12};
IEnumerable<int> numQuery1 =
from num in numbers
where num % 2 == 0
orderby num
select num;
IEnumerable<int> numQuery2 = numbers.Where(num => num % 2 == 0).OrderBy(n => n);
foreach (int i in numQuery1)
{
Console.Write(i + " ");
}
Console.WriteLine(System.Environment.NewLine);
foreach (int i in numQuery2)
{
Console.Write(i + " ");
}
Console.WriteLine(System.Environment.NewLine);
Console.WriteLine("Press any key to exit");
Console.ReadKey();
}
}
Lambda 表达式
请注意,在上⾯的⽰例中,条件表达式 (num % 2 == 0) 是作为内联参数传递到 Where ⽅法的:Where(num => num % 2 == 0). 。

此内联表达式称为lambda 表达式。

将代码编写为匿名⽅法或泛型委托或表达式树是⼀种便捷的⽅法,否则编写起来就要⿇烦得多。

在 C# 中,=> 是 lambda 运算符,可读
为“goes to”。

运算符左侧的 num 是输⼊变量,与查询表达式中的 num 相对应。

编译器可推断 num 的类型,因为它了解 numbers 是泛型 IEnumerable<T> 类型。

lambda 表达式与查询语法中的表达式或任何其他 C# 表达式或语句中的表达式相同;它可以包括⽅法调⽤和其他复杂逻辑。

“返回值”就是表达式结果。

若要开始使⽤ LINQ,您不必⼤量使⽤ lambda。

但是,特定查询只可使⽤⽅法语法表⽰,其中⼀些查询需要使⽤ lambda 表达式。

进⼀步熟悉 lambda 后,您会发现,在 LINQ ⼯具栏中,它们是强⼤且灵活的⼯具。

查询的组合性
在上⾯的代码⽰例中,请注意 OrderBy ⽅法是通过在对 Where 的调⽤中使⽤点运算符来调⽤的。

Where ⽣成筛选序列,然后 Orderby 通过对该序列排序来对它进⾏操作。

因为查询会返回 IEnumerable,所以您可通过将⽅法调⽤链接在⼀起,在⽅法语法中将这些查询组合起来。

这就是在您通过使⽤查询语法编写查询时编译器在后台所执⾏的操作。

并且由于查询变量不存储查询的结果,因此您可以随时修改它或将它⽤作新查询的基础,即使在执⾏它后。

相关文档
最新文档