go语言runtime.Gosched
webyh · · 2857 次点击 · · 开始浏览func say(s string) {
for i := 0; i < 2; i++ {
runtime.Gosched()
fmt.Println(s)
}
}
func main() {
go say("world")
say("hello")
}
输出:
hello
world
hello
1、先输出了hello,后输出了world
2、hello输出了2个,world输出了1个(因为第2个hello输出完,主线程就退出了,第2个world没机会了)
如果把代码中的runtime.Gosched()注释掉,执行结果为:
hello
hello
因为say("hello")这句占用了时间,等它执行完,线程也结束了,say("world")就没有机会了。
从这里也可以看出,goroutine并不是真正的"并行",goroutine都在一个线程里,它们之间通过不停的让出时间片轮流运行,达到类似运行的效果。
有疑问加站长微信联系(非本文作者)
入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889
关注微信- 请尽量让自己的回复能够对别人有帮助
- 支持 Markdown 格式, **粗体**、~~删除线~~、
`单行代码` - 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
- 图片支持拖拽、截图粘贴等方式上传
收入到我管理的专栏 新建专栏
func say(s string) {
for i := 0; i < 2; i++ {
runtime.Gosched()
fmt.Println(s)
}
}
func main() {
go say("world")
say("hello")
}
输出:
hello
world
hello
1、先输出了hello,后输出了world
2、hello输出了2个,world输出了1个(因为第2个hello输出完,主线程就退出了,第2个world没机会了)
如果把代码中的runtime.Gosched()注释掉,执行结果为:
hello
hello
因为say("hello")这句占用了时间,等它执行完,线程也结束了,say("world")就没有机会了。
从这里也可以看出,goroutine并不是真正的"并行",goroutine都在一个线程里,它们之间通过不停的让出时间片轮流运行,达到类似运行的效果。