
This scheduler is intended to live along the (stackless) coroutine based scheduler which is needed for WebAssembly and unsupported platforms. The stack based scheduler is somewhat simpler in implementation as it does not require full program transform passes and supports things like function pointers and interface methods out of the box with no changes. Code size is reduced in most cases, even in the case where no scheduler scheduler is used at all. I'm not exactly sure why but these changes likely allowed some further optimizations somewhere. Even RAM is slightly reduced, perhaps some global was elminated in the process as well.
27 строки
457 Б
Text
27 строки
457 Б
Text
len, cap of channel: 0 0 false
|
|
recv from open channel: 1 true
|
|
received num: 2
|
|
received num: 3
|
|
slept
|
|
received num: 4
|
|
received num: 5
|
|
received num: 6
|
|
received num: 7
|
|
received num: 8
|
|
recv from closed channel: 0 false
|
|
complex128: (+7.000000e+000+1.050000e+001i)
|
|
sum of n: 149
|
|
sum: 25
|
|
sum: 29
|
|
sum: 33
|
|
sum(100): 4950
|
|
deadlocking
|
|
select no-op
|
|
after no-op
|
|
sum: 5
|
|
did send one
|
|
select one n: 0
|
|
select n from chan: 55
|
|
select n from closed chan: 0
|
|
select send
|
|
sum: 235
|