Go语言的并发模型基本上遵照了CSP模型,goroutine间完全靠channel通信,没有像Unix进程的wait或waitpid的等待机制,也没有类似“POSIX Thread”中的pthread_join的汇合机制,更没有像kill或signal这类的中断机制**。每个goroutine结束后就自行退出销毁**,不留一丝痕迹。
runtime.Goexit函数在终止调用它的Goroutine的运行之前会先执行该Groution中还没有执行的defer语句。
/**
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延迟调度被执行。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)