加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

c# – 如何搜索LinkedList集合?

发布时间:2020-12-15 06:32:58 所属栏目:百科 来源:网络整理
导读:我有一个LinkedList T对象,其中T是具有名称为ID的属性的任意对象.我想使用ID作为搜索条件搜索我的收藏. 现在我知道我可以使用while循环进行搜索: LinkedListNodeMyObject element = myObject.First;while (element != myObject.Last){ if (element.Value.ID
我有一个LinkedList< T>对象,其中T是具有名称为ID的属性的任意对象.我想使用ID作为搜索条件搜索我的收藏.

现在我知道我可以使用while循环进行搜索:

LinkedListNode<MyObject> element = myObject.First;
while (element != myObject.Last)
{
    if (element.Value.ID == myID)
    break;

    element = element.Next;
}

但是我想知道是否有更优雅的解决方案.请注意,我需要LinkedListNode< T>因此,为了从那里浏览列表.

解决方法

您可以编写一个扩展方法来获取节点序列,并搜索:
public static IEnumerable<LinkedListNode<T>> Nodes<T>(this LinkedList<T> list)
{
    for (var node = list.First; node != null; node = node.Next)
    {
        yield return node;
    }
}

那么你可以做

var matchingNode = list.Nodes().FirstOrDefault(n => n.Value.Id == myId);

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读