博主介绍: 🚀自媒体 JavaPub 独立维护人,全网粉丝15w+,csdn博客专家、java领域优质创作者,51ctoTOP10博主,知乎/掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、GoLang
技术领域和副业。🚀
@[toc]
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延迟调度被执行。
<center>
<font face="黑体" color="red" size="4">回复1024,获取学习路线思维导图、加入GO计划学习</font>
</center>