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+unsubscr...@googlegroups.com.
For more options, visit https://groups.google.com/d/optout.

Reply via email to