Select与SelectMany的区别
2017-06-13 17:43
423 查看
Select() 和 SelectMany() 的工作都是依据源值生成一个或多个结果值。
Select() 为每个源值生成一个结果值。因此,总体结果是一个与源集合具有相同元素数目的集合。与之相反,SelectMany() 将生成单一总体结果,其中包含来自每个源值的串联子集合。作为参数传递到 SelectMany() 的转换函数必须为每个源值返回一个可枚举值序列。然后,SelectMany() 将串联这些可枚举序列以创建一个大的序列。
string[] text ={ "Albert was here", "Burke slept late", "Connor is happy" };
var tokens = text.Select(s => s.Split(''));
foreach (string[] line in tokens)
foreach (string token in line)
Console.Write("{0}.", token);
string[] text ={ "Albert was here", "Burke slept late", "Connor is happy" };
var tokens = text.SelectMany(s => s.Split(''));
foreach (string token in tokens)
Console.Write("{0}.", token);
下面两个插图演示了这两个方法的操作之间的概念性区别。在每种情况下,假定选择器(转换)函数从每个源值中选择一个由花卉数据组成的数组。
下图描述 Select() 如何返回一个与源集合具有相同元素数目的集合。
下图描述 SelectMany() 如何将中间数组序列串联为一个最终结果值,其中包含每个中间数组中的每个值。
Select() 为每个源值生成一个结果值。因此,总体结果是一个与源集合具有相同元素数目的集合。与之相反,SelectMany() 将生成单一总体结果,其中包含来自每个源值的串联子集合。作为参数传递到 SelectMany() 的转换函数必须为每个源值返回一个可枚举值序列。然后,SelectMany() 将串联这些可枚举序列以创建一个大的序列。
string[] text ={ "Albert was here", "Burke slept late", "Connor is happy" };
var tokens = text.Select(s => s.Split(''));
foreach (string[] line in tokens)
foreach (string token in line)
Console.Write("{0}.", token);
string[] text ={ "Albert was here", "Burke slept late", "Connor is happy" };
var tokens = text.SelectMany(s => s.Split(''));
foreach (string token in tokens)
Console.Write("{0}.", token);
下面两个插图演示了这两个方法的操作之间的概念性区别。在每种情况下,假定选择器(转换)函数从每个源值中选择一个由花卉数据组成的数组。
下图描述 Select() 如何返回一个与源集合具有相同元素数目的集合。
下图描述 SelectMany() 如何将中间数组序列串联为一个最终结果值,其中包含每个中间数组中的每个值。
相关文章推荐
- Windows Phone 7 IEnumerable<T>.Select和SelectMany的区别
- SelectMany 和 Select的区别
- Select与SelectMany的区别
- SelectMany 和 Select的区别
- IEnumerable.Select和SelectMany的区别
- Linq 中 Select 与SelectMany的区别
- IEnumerable.Select和SelectMany的区别
- Select()和SelectMany()的区别
- IEnumerable.Select和SelectMany的区别
- Windows Phone 7 IEnumerable<T>.Select和SelectMany的区别
- Select与SelectMany的区别
- IEnumerable.Select和SelectMany的区别
- IEnumerable.Select和SelectMany的区别
- SQL 中 SET 和 SELECT 有什么区别???
- select into 和 insert into select的区别
- LINQ的经典例子-Where,Select、SelectMany、SkipWhile子句中使用数组索引
- SELECT 与 SET 对变量赋值的区别(存储过程)
- MySQL中的行级锁SELECT FOR UPDATE 和LOCK IN SHARE MODE 区别
- [转] LINQ的经典例子-Where,Select、SelectMany、SkipWhile子句中使用数组索引。
- SELECT INPUT的一种样式定义 注意select放在表格内外在样式的区别