Go例程与操作系统线程的区别

Item 线程 Go例程
栈大小 固定大小,一般为2MB 变长大小,初始大小一般为2KB,运行时视需要扩展,最大可达1GB
调度器 内核调度器scheduler,每隔一段时间会有一个硬件定时器超时,导致scheduler被调用,scheduler会中断当前线程,并保存线程上下文,切换到另外的线程执行,每次调度都涉及用户态/内核态的切换 Go语言自带的调度器,采用m:n调度,即将m个go例程分发到n个操作系统线程,go例程切换不需要在用户态和内核态之间的切换,因此效率更高
ID 启动线程后会返回一个线程ID,可以用以后续保持类似map的本地存储结构,但这会导致类似全局变量滥用的类似问题 无ID
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章