SelectMany 和 Select的区别

如果我们看这两个扩展函数的定义很容易明白——Select是把要遍历的集合IEnumerable逐一遍历,每次返回一个T,合并之后直接返回一个IEnumerable,而SelectMany则把原有的集合IEnumerable每个元素遍历一遍,每次返回一个IEnumerable,把这些IEnumerable的“T”合并之后整体返回一个IEnumerable。

因此我们可以说一般情况下SelectMany用于返回一个IEnumerable<IEnumerable>的“嵌套”返回情况(把每个IEnumerable合并后返回一个整体的IEnumerable)。因此在嵌套的时候往往可以节省代码,例如输出带有以下的集合:

List<List<int>> numbers = new List<List<int>>()
{
  new List<int>{1,2,3},
  new List<int>{4,5,6},
  new List<int>{7,8,9}
};

通常情况下要遍历一个嵌套的数组,我们不得不采用二重循环(for或者foreach),不过现在我们可以借助SelectMany进行简化处理(把每个内嵌的List取出,因为每一个List都是IEnumerable,合并成一个大的IEnumerable)。简化如下:

var result = numbers.SelectMany(collection=>collection);

foreach(var item in result)
{
  ………………
}

 

 

 

from:https://blog.csdn.net/qq_29487981/article/details/83349232


posted @   幽冥狂_七  阅读(163)  评论(0编辑  收藏  举报
编辑推荐:
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
阅读排行:
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 单元测试从入门到精通
历史上的今天:
2018-06-05 toggle 1.9 以后就被删除了
2017-06-05 MySql 插入数据返回数据的Id值
点击右上角即可分享
微信分享提示