linuxwhilecpu99,while(true)循环与CPU占⽤率问题
linux下的sleep函数
⼀、为什么死循环占⽤CPU⾼
⼀个进程如果是死循环,那么占有的CPU会很⾼,可以操作系统时间⽚运⾏的,到了⼀定时间不是会⾃动切换到别的进程吗?既然即便是死循环,到时间还是会切换到别的进程,为什么占⽤CPU会⾼呢?
到时候的确会切换到别的进程。
可以这样理解:当切换到别的进程时,别的进程告诉系统⾃⼰没什么事情要做,不需要那么多的时间,这个时候系统就会切换到下⼀个进程,直到回到这个死循环的进程上,⽽这个进程⽆论什么时候都再循环,所以⼀直会报告有事情要做,系统就会把尽可能多的时间分给他。
实际上是这个死循环任务⽤光了别的进程节省下来的时间。
(虽然不是很准确,真正的进程调度实现⽐上⾯说的复杂得多,不过应该可以解释你的问题了)
⼆、之前写程序的时候⼀直没有主动注意CPU占⽤的问题,今天在进⾏RTSP服务端测试的时候发现只是接⼊了⼀两个连接,CPU的占⽤率已经达到了100%,吓死我了~虽然之前已经预料到CPU占⽤会很⾼,但实际测试结果还是让我出了⼀⾝冷汗,这样的程序怎么能够发布使⽤呢?应该逐渐关注程序性能算法优化这⽅⾯的问题。当然,导致CPU占⽤率如此之⾼的元凶就是程序中的⼏个while(true)死循环。
⽤代码解释如下:
while(true){
//your code
}
改进之后:
while(true){
Sleep(1);
//your code
}其实就是添加了⼀句“Sleep(1)”,但是CPU占⽤率就直接从100%跌到了1%左右。
Sleep()是Windows API线程调度相关的函数,将当前线程置⼊等待状态,并让它等待⼀段指定的时间间隔(以毫秒ms为单位),零值表⽰放弃该线程时限的剩余部分。
Comments:CPU是以纳秒级单位运转的!
Windows98 系统是需要加上Sleep(x)函数来将控制权交割给其他进程的
⾄于Window的其他系列,就不⼤清楚如何处理
但是有⼀点确定,就是你的线程中加上Sleep函数,的确会减少CPU占⽤率,只不过牺牲程序的相应速度

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。