简介:
通过使用 C# 3.0 中引入的声明性查询语法,介绍性 LINQ 文档中的多数查询都被编写为查询表达式。 但是,.NET 公共语言运行时 (CLR) 本身并不具有查询语法的概念。 因此,在编译时,查询表达式会转换为 CLR 的内容:方法调用。 这些方法称为“标准查询运算符”,它们具有如下名称: Where、 Select、 GroupBy、 Join、 Max、 Average 等。可以通过使用方法语法而非查询语法来直接调用这些方法。
通常我们建议使用查询语法,因为它通常更简单、更易读;但是方法语法和查询语法之间并无语义上的区别。 此外,一些查询(如检索匹配指定条件的元素数的那些查询或检索具有源序列中的最大值的元素的查询)只能表示为方法调用。 System.Linq 命名空间中的标准查询运算符的参考文档通常使用方法语法。 因此,即使在开始编写 LINQ 查询时,熟悉如何在查询和查询表达式本身中使用方法语法也非常有用。
简单的理解即是,Linq的查询语法一般都有对应的方法语法。
使用
- Linq 查询语法与方法语法使用比较。
- 条件表达式 (num % 2 == 0) 是作为内联参数传递到 Where 方法的:Where(num => num % 2 == 0).。此内联表达式称为 lambda 表达式。 将代码编写为匿名方法或泛型委托或表达式树是一种便捷的方法。
查询 | 方法 |
---|---|
from num in numbers | numbers |
where num % 2 == 0 | Where(num => num % 2 == 0) |
orderby num | OrderBy(n => n) |
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 + " ");
}
/*输出:6 8 10 12*/
Console.WriteLine(System.Environment.NewLine);
foreach (int i in numQuery2)
{
Console.Write(i + " ");
}
/*输出:6 8 10 12*/
Console.ReadKey();
}
}