长期饭票

大家好,请喊我序员!
QQ:15838986
  首页  :: 新随笔  :: 联系 :: 订阅 订阅  :: 管理

[转]LINQ 和泛型类型

Posted on 2011-02-16 17:20  Baode  阅读(304)  评论(0编辑  收藏  举报

LINQ 查询基于泛型类型,在 .NET Framework 的 2.0 版中引入了泛型类型。您无需深入了解泛型即可开始编写查询。但是,您可能需要了解两个基本概念:

  • 当您创建泛型集合类(如 List<(Of <(T>)>))的实例时,您将“T”替换为列表将包含的对象的类型。例如,字符串列表表示为 List,Customer 对象列表表示为 List。泛型列表是强类型的,且提供了比将其元素存储为 Object 的集合更多的好处。如果您尝试将 Customer 添加到 List,则会在编译时出现一条错误。泛型集合易于使用的原因是您不必执行运行时类型强制转换。
  • IEnumerable<(Of <(T>)>) 是一个接口,通过该接口,可以使用 foreach 语句来枚举泛型集合类。泛型集合类支持 IEnumerable<(Of <(T>)>),就像非泛型集合类(如 ArrayList)支持 IEnumerable。

LINQ 查询中的 IEnumerable 变量

LINQ 查询变量类型化为 IEnumerable<(Of <(T>)>) 或派生类型,如 IQueryable<(Of <(T>)>)。当您看到类型化为 IEnumerable 的查询变量时,这只意味着在执行该查询时,该查询将生成包含零个或多个 Customer 对象的序列。

IEnumerable<Customer> customerQuery =
from cust
in customers
where cust.City == "London"
select cust;

foreach (Customer customer in customerQuery)
{
Console.WriteLine(customer.LastName
+ ", " + customer.FirstName);
}

 

让编译器处理泛型类型声明

如果您愿意,可以使用 var 关键字来避免使用泛型语法。var 关键字指示编译器通过查看在 from 子句中指定的数据源来推断查询变量的类型。下面的示例生成与上一个示例相同的编译代码:

var customerQuery2 =
from cust
in customers
where cust.City == "London"
select cust;

foreach(var customer in customerQuery2)
{
Console.WriteLine(customer.LastName
+ ", " + customer.FirstName);
}

 

当变量的类型明显或显式指定嵌套泛型类型(如由组查询生成的那些类型)并不重要时,var 关键字很有用。通常,我们建议如果您使用 var,应意识到这可能使您的代码更难以让别人理解。