最近写一go工具,运行老是听到cpu风扇吼得凶,开始不以为然,认为是电脑太垃圾。后面越想越不对劲,怎么go程序cpu占用这么高的吗?不太至于吧,闲空下来,做了个测试,发现果然应该是代码的问题。于时开始排查,最终定位到goroutine中使用到for{},大致代码如下:
func routine1 {
for {
... // something
}
}
程序运行到是没问题,但这个goroutine可能不会主动释放cpu,由于从嵌入式c转过来,在嵌入领域主循环就是这么写,然而在x86平台,做完事情不释放其实也没太大问题,相当于整个cpu全力处理这个协程,这就会导致cpu占用过高,但这一般不太是我们希望看到的结果。所以处理办法是定时主动释放cpu控制权。那么代码就应该是这样:
func routine1 {
for {
time.Sleep(time.Nanosecond)
... // something
}
}
for循环第一行放一小段延时是个好习惯,万一something里面没有主动释放cpu的功能,那cpu就会飙得很高