文章目录
Go语言的并发模型基本上遵照了CSP模型,goroutine间完全靠channel通信,没有像Unix进程的wait或waitpid的等待机制,也没有类似“POSIX Thread”中的pthread_join的汇合机制,更没有像kill或signal这类的中断机制。每个goroutine结束后就自行退出销毁 ,不留一丝痕迹。
/** Goexit 调用runtime.goExit()将立即终止当前goroutine执行,调度器 确保所有已注册defer延迟调度被执行。 */ package main import ( "fmt" "runtime" ) func main(){ go func(){ defer fmt.Println("A defer go") func(){ defer fmt.Println("B defer go") runtime.Goexit() fmt.Println("B") }() fmt.Println("A") }()//别忘了() //阻塞,防止结束 for{} //输出 /** F:\goWorkSpace\study\05协程>go run 06_runtimeGoexit.go B defer go A defer go */ }
调用runtime.goExit()将立即终止当前goroutine执行,调度器确保所有已注册defer延迟调度被执行。