加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 大数据 > 正文

golang 里goroutine产生的线程数量

发布时间:2020-12-16 18:57:24 所属栏目:大数据 来源:网络整理
导读:import "os" func main() { for i:=0; i20; i++ { go func() { for { b:=make([]byte,10) os.Stdin.Read(b) // will block } }() } select{} } 会产生21个线程: runtime scheduler(src/pkg/runtime/proc.c)会维护一个线程池,当某个goroutine被block后,sch
import "os"

func main() {
for i:=0; i<20; i++ {
go func() {
for {
b:=make([]byte,10)
os.Stdin.Read(b) // will block
}
}()
}
select{}
}
会产生21个线程:
runtime scheduler(src/pkg/runtime/proc.c)会维护一个线程池,当某个goroutine被block后,scheduler会创建一个新线程给其他ready的goroutine
GOMAXPROCS控制的是未被阻塞的所有goroutine被multiplex到多少个线程上运行

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读