免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1034 | 回复: 2

[内核入门] linux下一个程序相连的两次被调度执行的间隔是多长时间? [复制链接]

论坛徽章:
2
2015年辞旧岁徽章
日期:2015-03-03 16:54:152015元宵节徽章
日期:2015-03-06 15:52:30
发表于 2016-03-03 13:47 |显示全部楼层
linux下一个程序相连的两次被调度执行的间隔是多长时间?一直对这个没有任何概念。

假设一个linux系统上有50个进程在运行,除了一个进程是所谓的CPU hog外(代码如下),其余进程的大部分时间是空闲状态。
这种情况下,cpu hog 某次被调度执行,无间断的运行了n条指令后被调度走了,此时刻为t0, 过了一会,调度器将cpu hog再次调度进来执行,此时刻为t1.
t1-t0 对目前的常见的PC来说大概是个什么量级的数?

  1. int main() {

  2.     while(1);
  3.     return 0
  4. }
复制代码

论坛徽章:
9
辰龙
日期:2014-08-18 20:38:42未羊
日期:2014-09-04 08:50:45丑牛
日期:2014-09-06 00:12:55寅虎
日期:2014-12-22 20:50:56摩羯座
日期:2015-01-14 22:28:15巳蛇
日期:2015-01-23 20:39:272015年辞旧岁徽章
日期:2015-03-03 16:54:1515-16赛季CBA联赛之青岛
日期:2016-03-13 23:37:1915-16赛季CBA联赛之深圳
日期:2016-03-29 18:52:38
发表于 2016-03-13 10:52 |显示全部楼层
这种情况一,CPU应该都被它占了。大部份情况下是不会切换它出去的。切换出去的话就看切到准头上了,如是是FIFO,那就得等FIFO主动退出罗。如果切到另一个睡醒的CFS,是可以从CFS的代码上算出来个大概值的。如果你只是想看一下,不想去深入了解,可以直接通过ftrace功能,测出来。

论坛徽章:
0
发表于 2016-03-18 17:30 |显示全部楼层
对于while(1),不会主动放弃CPU,只能被抢占,所以它会跑满分配给它的时间。
关于CFS,每一个进程的最大时间跟它的优先级以及当前CPU上的runnable的进程有关。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP