C# 中的 SelectMany
是一個LINQ擴展方法,它用于將多個集合或可迭代對象中的元素合并到一個連續的序列中。以下是 SelectMany
的一些常見應用場景:
扁平化嵌套集合:
當你有一個集合,其中每個元素本身也是一個集合(如列表、數組等),并且你想要將這些嵌套集合中的所有元素扁平化為一個單一列表時,可以使用 SelectMany
。
var nestedList = new List<List<int>> {
new List<int> { 1, 2 },
new List<int> { 3, 4 },
new List<int> { 5, 6 }
};
var flattenedList = nestedList.SelectMany(innerList => innerList).ToList();
// 輸出: [1, 2, 3, 4, 5, 6]
連接多個序列:
如果你有多個獨立的序列,并且想要將它們連接成一個單一的序列,可以使用 SelectMany
。
var sequence1 = new List<int> { 1, 2, 3 };
var sequence2 = new List<int> { 4, 5, 6 };
var combinedSequence = sequence1.SelectMany(x => sequence2).ToList();
// 輸出: [1, 4, 2, 5, 3, 6]
注意:上面的示例中,SelectMany
將兩個序列中的元素按順序連接。如果你想保持原始序列的順序,并且每個源序列中的元素可以重復出現,可以使用 Concat
方法代替。
將多個源序列的元素轉換為指定類型:
SelectMany
還可以與 Select
結合使用,以便將多個源序列中的元素轉換為指定的類型。
var source1 = new List<int> { 1, 2, 3 };
var source2 = new List<string> { "a", "b", "c" };
var combined = source1.SelectMany(x => source2.Select(y => new { Value = x, Text = y })).ToList();
// 輸出: [{ Value=1, Text="a"}, { Value=1, Text="b"}, { Value=1, Text="c"}, { Value=2, Text="a"}, { Value=2, Text="b"}, { Value=2, Text="c"}, { Value=3, Text="a"}, { Value=3, Text="b"}, { Value=3, Text="c"}]
處理異步操作:
在處理異步操作時,SelectMany
可以用于將多個異步操作的結果合并到一個單一的異步操作中。
var tasks = new List<Task<int>> {
Task.Run(() => 1),
Task.Run(() => 2),
Task.Run(() => 3)
};
var results = await Task.WhenAll(tasks).SelectMany(task => task).ToList();
// 輸出: [1, 2, 3]
將LINQ查詢結果轉換為其他類型:
SelectMany
還可以用于將LINQ查詢的結果轉換為其他類型,例如將其轉換為字典。
var people = new List<Person> {
new Person { Name = "Alice", Age = 30 },
new Person { Name = "Bob", Age = 25 },
new Person { Name = "Charlie", Age = 35 }
};
var nameAgeDictionary = people.SelectMany(person => person.Name.Select(name => new { Name = name, Age = person.Age })).ToDictionary(x => x.Name, x => x.Age);
// 輸出: { "Alice" => 30, "Bob" => 25, "Charlie" => 35 }
這些只是 SelectMany
的一些常見應用場景。實際上,SelectMany
的用途非常靈活,可以根據具體需求進行組合和調整。