looks better solution to restrict goroutines to continue it's pending work

Thanks for the reply


On Monday, August 7, 2017 at 8:21:09 AM UTC+5:30, Timothy Raymond wrote:
>
> I'm not entirely sure, but my intuition says that using `time.After` like 
> that with pending sends from another goroutine will cause that goroutine to 
> leak. A better solution may be to use the `WithTimeout` functionality of 
> the `context` package and then periodically check the `Done()` channel to 
> see if the timeout has expired. It works something like this if you imagine 
> `HeavyWork` is a call to an external API: 
> https://play.golang.org/p/DRtgNBLnE5 .
>
> On Sunday, August 6, 2017 at 3:53:36 AM UTC-4, Abhijit Desai wrote:
>>
>> Can you please help with below code to get output at specific cutoff time 
>> and exit
>>
>> Thanks in advance
>>
>> Abhi
>>
>>
>>
>> package main
>>
>> import "time"
>> import "fmt"
>>
>> func main() {
>>
>>     c1 := make(chan string)
>>     
>>     go func() { //Sending data after certain time
>>   
>>         c1 <- "result 1"
>>
>>         time.Sleep(time.Second * 1)
>>         c1 <- "result 2 afer 1 sec"
>>
>>         time.Sleep(time.Second * 1)
>>         c1 <- "result 2 afer 2 sec"
>>
>>         time.Sleep(time.Second * 1)
>>         c1 <- "result 2 afer 3 sec"
>>
>>         time.Sleep(time.Second * 1)
>>         c1 <- "result 2 afer 4 sec"
>>
>>         time.Sleep(time.Second * 1)
>>         c1 <- "result 2 afer 5 sec"
>>     }()
>>
>>     select {
>>         case <-time.After(time.Second * 4): { //cut off 4s and return the 
>> value
>>             res := <-c1                    
>>             fmt.Println(res)  // expecting result "result 2 afer 3 sec" 
>> but returning "result 1"
>>         }
>>     }
>> }
>>
>

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