[OT] Stackless fibers/coroutines
Nick Sabalausky via Digitalmars-d
digitalmars-d at puremagic.com
Mon Sep 26 07:31:52 PDT 2016
On 09/26/2016 02:42 AM, Jacob Carlborg wrote:
> On 2016-09-25 20:16, Nick Sabalausky wrote:
>> I don't see why not, but there would be one notable drawback: You could
>> only have one instance existing at a time (per thread).
>
> But how does it work in languages which don't pass in the state
> explicitly, like with "yield" in C#?
>
> Or async/await? I guess one doesn't call the function multiple times in
> the same way instead it's done automatically under the hood, passing in
> the state which might be stored in the "Task" that is returned?
>
I don't know about async/await, because all my C# work was with versions
of C# that predated those. But as for C#'s yield functions, yes, that's
my understanding: It's hidden magic automatically inserted by the compiler.
As a side note, that actually makes D's opApply a very interesting case,
really:
Instead of doing like the other implementations and "yielding" by
removing the top function from the callstack (ie "returning"), opApply
does the oppposite: It yields by pushing whatever function it's yielding
*to*, *onto* the callstack. So its state is stored on the stack, no need
for magic. The downside is, that's exactly what makes it impossible for
opApply to be used as a range (at least without introducing a true fiber
to save/restore the callstack): popFront *must* return in order for the
user's algorithm to call front and obtain the current element - because
that's how the range interface works.
>
> The above code compiles, after removing the extra "return+case:".
>
Really? I may have to look into this more then.
Hmm, well for starters, according to
<http://dlang.org/spec/statement.html#GotoStatement>:
"It is illegal for a GotoStatement to be used to skip initializations."
Although if that's true, I don't know why that example compiled. Maybe
because "foo" wasn't used from "case 2:" onward? Maybe it failed to
notice the initialization since it was in an if condition? Or maybe the
compiler forgot to implement the same "can't skip initialization" check
for switch/case?
More information about the Digitalmars-d
mailing list