The code suggests, that select is indeed not fair:
https://github.com/golang/go/blob/a4d03a9bf7604b727abd0a1ebfb118ff6366ee50/src/runtime/stubs.go#L109
Which seems fine to me. A fair, uniform PRNG for ranges that are not powers
of two gets a fair bit of overhead and no program should depend on
uniformity of select for correctness anyway.

On Fri, Oct 27, 2017 at 10:28 PM, T L <tapir....@gmail.com> wrote:

> It looks the distribution of the RNG results depends on the number of
> cases.
> The third case only gets the lowest possibility of there are 6 cases,
>
>
> On Friday, October 27, 2017 at 4:21:12 PM UTC-4, T L wrote:
>>
>> A better example to show the inhomogeneity of the selected possibilities
>> of each case.
>>
>> package main
>>
>> import "fmt"
>>
>> func main() {
>>     foo := make(chan struct{})
>>     close(foo)
>>     var a, b, c, d, e, f, g float64
>>     fa := func(){a++}
>>     fb := func(){b++}
>>     fc := func(){c++}
>>     fd := func(){d++}
>>     fe := func(){e++}
>>     ff := func(){f++}
>>     fg := func(){g++}
>>     for i := 0; i < 1000000; i++ {
>>         select {
>>         case <-foo: fa()
>>         case <-foo: fb()
>>         case <-foo: fc()
>>         case <-foo: fd()
>>         case <-foo: fe()
>>         case <-foo: ff()
>>         case <-foo: fg()
>>         }
>>     }
>>     fmt.Println(a/a)
>>     fmt.Println(b/a)
>>     fmt.Println(c/a)
>>     fmt.Println(d/a)
>>     fmt.Println(e/a)
>>     fmt.Println(f/a)
>>     fmt.Println(g/a)
>> }
>>
>> result:
>>
>> 1
>> 0.9999052991869258
>> 0.9015652691532394
>> 0.9691884140319548
>> 0.966320332264567
>> 0.9669020658305938
>> 0.9604624105415533
>>
>> On Friday, October 27, 2017 at 4:08:39 PM UTC-4, T L wrote:
>>>
>>> The following program constantly prints a value larger than 1.02
>>>
>>> package main
>>>
>>> import "fmt"
>>>
>>> func main() {
>>>     foo, bar := make(chan struct{}), make(chan struct{})
>>>     close(foo)
>>>     close(bar)
>>>     x, y := 0.0, 0.0
>>>     f := func(){x++}
>>>     g := func(){y++}
>>>     for i := 0; i < 1000000; i++ {
>>>         select {
>>>         case <-bar: g()
>>>         case <-foo: f()
>>>         case <-bar: g()
>>>         case <-foo: f()
>>>         case <-bar: g()
>>>         case <-foo: f()
>>>         }
>>>     }
>>>     fmt.Println(x/y)
>>> }
>>>
>>> if the last two cases are removed, then it becomes quit fair.
>>>
>> --
> 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.
>

-- 
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