go语言实战中有段代码不明白,请问哪位帮忙给看一下,多谢

darren_lou · · 2695 次点击
单核状态下,如果一个时间片执行的时间是1s,但是你的一个goroutine中打印26句话,才花了0.1秒的话,就是在一个时间片内执行完了,当然永远会先打印大写的。你把打印大小和小写都写成循环打印,输入一万次,应该可以看到到大小写会混乱输出。
#7
更多评论
这里应该是单核状态下调度器算法决定的,我一开始以为是defer先进后出的机制造成的结果,后来试了一下for循环输出0-9,得到的结果是9012345678,所以排除defer入栈的可能,目前以我的理解是这样的,你可以试试你单核时候打印0-9是不是和我一样的结果
#1
go内部有一套协程调度机制,类似cpu线程上下文切换,每个线程会给一个固定的时间片来执行,时间片结束之后会暂停这个线程并将上下文切换到下一个线程。这里的意思可能是说这个goroutine在时间片之内就执行完成了,并没有发生上下文切换,而且runtime.GOMAXPROCS(1)是设置最大并行数,所以相当于是单核,不存在多个goroutine并行。 那么问题来了,为什么始终会先打印大写,坐等大佬
#2