Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

C# infinite iteration

Is there anything similar in C# to Java's Stream.iterate? The closest thing I could find was Enumerable.Range but it is much different.

The reason I'm asking is that I've been just watching some presentation about good programming principles and there was a thread about declarative vs. imperative code. What caught my attention was a way you can generate a pseudo-infinite set of data.

like image 652
SOReader Avatar asked Nov 07 '14 13:11

SOReader


1 Answers

There isn't an exact equivalent in the .Net framework but there is one in the MoreLINQ library:

foreach (var current in MoreEnumerable.Generate(5, n => n + 2).Take(10))
{
    Console.WriteLine(current);
}

It's also very simple to recreate it using yield:

public static IEnumerable<T> Iterate<T>(T seed, Func<T,T> unaryOperator)
{
    while (true)
    {
        yield return seed;
        seed = unaryOperator(seed);
    }
}

yield enables to create an infinite enumerator because:

When a yield return statement is reached in the iterator method, expression is returned, and the current location in code is retained. Execution is restarted from that location the next time that the iterator function is called.

From yield (C# Reference)

like image 158
i3arnon Avatar answered Sep 30 '22 22:09

i3arnon