Thank you! Got it. Regards, Sundar
On Wednesday, January 24, 2018 at 3:23:04 PM UTC-8, Matt Harden wrote: > > When the program exits, all goroutines die instantly. The doc is saying > that the program does not wait for any goroutine to complete except the > "main" goroutine (the one that invoked the function main at startup). If > you do want to wait for other goroutines to exit before exiting the > program, which is often something you do want, that can be done using > sync.WaitGroup or other synchronization tools like channels. In the case of > Tamas's goroutine, nothing in main waits for it, assuming the program isn't > sent an interrupt signal, so the goroutine never "completes". It does > "exit" though, because all goroutines are part of the program, and when the > program exits, it exits entirely. Any goroutine that was running as part of > the program isn't running anymore, and in fact doesn't even "exist" in any > meaningful sense anymore. > > You are correct that contexts can be used to inform goroutines when to > perform cleanup steps and/or exit cleanly, but if you want to ensure that > the cleanup actually completes, you need to wait for the goroutine to > finish before returning from main (or running os.Exit, log.Fatal, panicking > without recovering, etc.). Otherwise the goroutine may abruptly stop > running at any time as the program exits. > > I hope that helps to clarify the documentation for you. > > On Wed, Jan 24, 2018 at 11:03 PM Sundar Nadathur <ns1.s...@gmail.com > <javascript:>> wrote: > >> I am probably mis-understanding or missing something. The golang spec >> <https://golang.org/ref/spec#Program_execution> says: >> Program execution begins by initializing the main package and then >> invoking the function main. When that function invocation returns, the >> program exits. *It does not wait for other (non-main) goroutines to >> complete*. >> >> I gather that the context mechanism addresses this issue, by requiring >> every relevant go routine to get a context as a parameter and to check for >> ctx.Done channel. Since calling cancel() would send a message through that >> channel, every goroutine that is designed to listen on that channel would >> 'get the message' and can do their own cleanup/exit. >> >> However, this specific goroutine does not receive the context. The golang >> spec seems to say that it is not guaranteed to exit when the app dies or >> exits. Please clarify. >> >> Regards, >> Sundar >> >> >> On Wednesday, January 24, 2018 at 12:05:35 PM UTC-8, Tamás Gulácsi wrote: >>> >>> if the main goroutine exits, all other goroutines exit, too. >> >> -- >> 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.