在 MSDN 上,我发现了 Enumerable.GroupBy 方法的以下重载:
public static IEnumerable<TResult> GroupBy<TSource, TKey, TElement, TResult>(
this IEnumerable<TSource> source,
Func<TSource, TKey> keySelector,
Func<TSource, TElement> elementSelector,
Func<TKey, IEnumerable<TElement>, TResult> resultSelector)
以及以下示例:
List<Pet> petsList =
new List<Pet>{ new Pet { Name="Barley", Age=8.3 },
new Pet { Name="Boots", Age=4.9 },
new Pet { Name="Whiskers", Age=1.5 },
new Pet { Name="Daisy", Age=4.3 } };
var query = petsList.GroupBy(
pet => Math.Floor(pet.Age), //keySelector
pet => pet.Age, //elementSelector
(baseAge, ages) => new //resultSelector
{
Key = baseAge,
Count = ages.Count(),
Min = ages.Min(),
Max = ages.Max()
});
虽然我明白这段代码是如何工作的,但我想不出它的实际用途。正如我现在看到的,这将返回一个 Enumerable
,其中包含在代码末尾定义的匿名类型的元素。但为什么 GroupBy 方法会返回一个未分组的枚举?不能通过使用 Select、OrderBy 等来完成同样的事情吗?或者这个重载的主要目的是自己定义一个 Dictionary
作为 TResult
的一部分?
最佳答案
以下两个查询将产生相同的结果。
var queryA = source
.GroupBy(x => x.Id)
.Select(g => new { Id = g.Key, Count = g.Count() });
var queryB = source
.GroupBy(x => x.Id, (key, g) => new { Id = key, Count = g.Count() });
区别在于第一个查询必须实例化一个 IGrouping<TKey, TElement>
每组,而第二个查询没有。你应该更喜欢 queryB
在这种情况下。
关于c# - 带有 resultselector 重载的 Linq GroupBy 方法有什么用?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33905631/