If a select statement has multiple channels ready when it runs, then it 
will choose one at a random. So if you fire something across a channel that 
holds a resource, like an open file descriptor - you have no guarantees 
that the other end of the channel receives it. The (possibly full) channel 
will get garbage collected later and the resource will leak in that case.

Some code that explains things better than my clumsy prose:

Receiver:
 // Wait on the channel, or for timeout
 select {
 case fd := <-channel:
     return fd, nil
 case <-time.After(queue.timeout):
     return nil, ErrTimeoutElapsed
 }

Sender:
 channel <- fd

What happens when the timeout races with the channel send? I think it's 
possible the select handles the timeout in that case and leaves the channel 
containing a connection alone.

Am I right that this is a problem? How might I fix this code?

Thanks,
Dan

-- 
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.
To view this discussion on the web visit 
https://groups.google.com/d/msgid/golang-nuts/5cda1189-2761-4110-8e9e-1d7311fd97fe%40googlegroups.com.
For more options, visit https://groups.google.com/d/optout.

Reply via email to