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

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