gpt4 book ai didi

c# - 带有 resultselector 重载的 Linq GroupBy 方法有什么用?

转载 作者:太空宇宙 更新时间:2023-11-03 18:26:10 26 4
gpt4 key购买 nike

在 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/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com