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.

Reply via email to