Как я могу получить доступ к следующему значению в коллекции внутри цикла foreach в C #? - PullRequest
27 голосов
/ 08 марта 2010

Я работаю в C # и с отсортированными List<T> структурами. Я пытаюсь перебрать List, и для каждой итерации я хотел бы получить доступ к следующему члену списка. Есть ли способ сделать это?

Пример псевдокода:

foreach (Member member in List)
{
    Compare(member, member.next);
}

Ответы [ 6 ]

55 голосов
/ 08 марта 2010

Вы не можете. Используйте вместо вместо

for(int i=0; i<list.Count-1; i++)
   Compare(list[i], list[i+1]);
18 голосов
/ 08 марта 2010

Вместо этого вы можете оставить предыдущее значение:

T prev = default(T);
bool first = true;
foreach(T item in list) {
    if(first) {
        first = false;
    } else {
        Compare(prev, item);
    }
    prev = item;
}
4 голосов
/ 08 марта 2010

Если бы вы были так склонны, вы, вероятно, могли бы написать метод Extension и для этого ...

public static void ForEachNext<T>(this IList<T> collection, Action<T, T> func)
{
    for (int i = 0; i < collection.Count - 1; i++)
        func(collection[i], collection[i + 1]);
}

Использование:

List<int> numList = new List<int> { 1, 3, 5, 7, 9, 11, 13, 15 };

numList.ForEachNext((first, second) => 
{
    Console.WriteLine(string.Format("{0}, {1}", first, second));
});
3 голосов
/ 08 марта 2010

Используйте регулярный цикл for с индексом, сравните список [i] и список [i + 1]. (Но убедитесь, что цикл только до второго индекса.)

Или, если вы действительно хотите использовать foreach, вы можете сохранить ссылку участника на предыдущего участника и проверить в следующий раз. Но я бы не рекомендовал это.

2 голосов
/ 08 марта 2010

LINQ может быть вашим другом здесь. Этот подход будет работать со всем, что IEnumerable , а не только с коллекциями IList , что очень полезно, если ваша коллекция никогда не заканчивается или вычисляется на лету иным образом:

class Program {
    static void Main(string[] args) {
        var list = new List<Int32> { 1, 2, 3, 4, 5 };
        foreach (var comparison in list.Zip(list.Skip(1), Compare)) {
            Console.WriteLine(comparison);
        }
        Console.ReadKey();
    }

    static Int32 Compare(Int32 first, Int32 second) {
        return first - second;
    }
}
1 голос
/ 07 августа 2016
XmlNode root = xdoc.DocumentElement;
XmlNodeList nodeList = root.SelectNodes("descendant::create-backup-sets/new-file-system-backup-set");

for (int j = 0; j < nodeList.Count; j++ )
{                
    for (int i = 0; i <= nodeList.Item(j).ChildNodes.Count - 1; i++)
    {
        if (nodeList.Item(j).ChildNodes[i].Name == "basic-set-info")
        {
            if (nodeList.Item(j).ChildNodes[i].Attributes["name"].Value != null)
            {
                // retrieve backup name
                _bName = nodeList.Item(j).ChildNodes[i].Attributes["name"].Value.ToString();
            }
        }
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...