On Saturday, October 28, 2017 at 11:11:02 PM UTC-7, John Souvestre wrote: > > Ø Round robin isn't implementable. There's no place to store the state > for an individual select. > > > > Couldn’t a place be allocated? Since it would be local to a goroutine, > put it on the stack. > > > > Ø I'm not sure how you would even define round robin. What's the unit > that's being round-robined? An individual select statement across all > goroutines? A select statement and goroutine pair? A select statement + > function instance pair? > > > > An individual select in a goroutine. > > >
So a goroutine has storage for every possible select in the program? If you do it statically, that's a lot of storage. If you do it dynamically, then you have a dynamic select -> nextcase map you have to maintain. You can put that storage on the stack, but just barely: it has to live as long as the goroutine does, so it has to be at the very top. > John > > John Souvestre - New Orleans LA > > > > *From:* golan...@googlegroups.com <javascript:> [mailto: > golan...@googlegroups.com <javascript:>] *On Behalf Of * > keith....@gmail.com <javascript:> > *Sent:* 2017 October 28, Sat 18:38 > *To:* golang-nuts > *Subject:* Re: [go-nuts] Re: select is still a little unfair if there are > more than 4 cases? > > > > On Saturday, October 28, 2017 at 2:59:53 PM UTC-7, John Souvestre wrote: > > Ø I don't think it needs to be uniformly fair. It just needs to prevent > starvation of a channel for infinity. Any proof would have progress covered > if we pick every channel once in a while, even under a heavily unfair > weighting. You have to balance out the overhead of rolling a fair dice and > the speed at which you can select on channels. > > > > If it were uniformly fair then you couldn’t guarantee picking every > channel once in a while. Statistically it would be become more and more > probable, but never 100%. > > > > Why not just use round-robin? That would guarantee it and it’s a faster > algorithm, I would think. Also, it would sometimes save checking all cases > since you could check them in order, stopping when (if) you found one ready. > > > > Are there situations where it is better for it to be random or is there > some implementation advantage (not having to save state for the select)? > > > > > > Round robin isn't implementable. There's no place to store the state for > an individual select. And you can't store the state in the G (goroutine) > or M (os thread) because then: > > for { > > select { > > case <-x: > > case <-y: > } > > select { > > case <-y: > > case <-x: > } > } > > > > would never read from y (or x, depending on the initial state). > > > > I'm not sure how you would even define round robin. What's the unit > that's being round-robined? An individual select statement across all > goroutines? A select statement and goroutine pair? A select statement + > function instance pair? > > (The last one is actually implementable - but then select statements > behave differently if you wrap them in a function.) > > > > John > > John Souvestre - New Orleans LA > > -- > You received this message because you are subscribed to the Google Groups > "golang-nuts" group. > To unsubscribe from this group and stop receiving emails from it, send an > email to golang-nuts...@googlegroups.com <javascript:>. > For more options, visit https://groups.google.com/d/optout. > -- You received this message because you are subscribed to the Google Groups "golang-nuts" group. To unsubscribe from this group and stop receiving emails from it, send an email to golang-nuts+unsubscr...@googlegroups.com. For more options, visit https://groups.google.com/d/optout.