gpt4 book ai didi

LINQ递归函数?

转载 作者:行者123 更新时间:2023-12-02 03:06:57 24 4
gpt4 key购买 nike

我们以这个n层深层结构为例:

public class SomeItem 
{
public Guid ID { get;set; }
public string Name { get; set; }
public bool HasChildren { get;set; }
public IEnumerable<SomeItem> Children { get; set; }
}

如果我想通过 ID(结构中的任何位置)获取特定项目,是否可以使用一些 LINQ 优点在单个语句中轻松获取它,或者我是否必须使用一些递归函数,如下所示:

   private SomeItem GetSomeItem(IEnumerable<SomeItem> items, Guid ID)
{
foreach (var item in items)
{
if (item.ID == ID)
{
return item;
}
else if (item.HasChildren)
{
return GetSomeItem(item.Children, ID);
}
}
return null;
}

最佳答案

LINQ 并没有真正很好地“执行”递归。您的解决方案似乎是合适的 - 尽管我不确定 HasChildren 是否真的需要...为什么不只对没有子项的项目使用空列表?

另一种方法是编写一个 DescendantsAndSelf 方法,该方法将返回所有后代(包括项目本身),如下所示;

// Warning: potentially expensive!
public IEnumerable<SomeItem> DescendantsAndSelf()
{
yield return this;
foreach (var item in Children.SelectMany(x => x.DescendantsAndSelf()))
{
yield return item;
}
}

但是,如果树很深,那么最终效率会非常低,因为每个项目都需要“通过”其祖先的所有迭代器。韦斯·戴尔有blogged about this ,显示出更高效的实现。

无论如何,如果您有这样的方法(无论它是如何实现的),您都可以使用普通的“where”子句来查找项目(或 First/FirstOrDefault 等)。

关于LINQ递归函数?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4814242/

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