免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1935 | 回复: 4
打印 上一主题 下一主题

[Linux] 为什么time命令得到的结果,总时间不等于sys时间+user时间? [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2013-05-26 09:25 |只看该作者 |倒序浏览
5可用积分
如题,我写了个很小的程序(m.cpp),来耗费cpu:

  1. #include<stdio.h>
  2. int main(void){
  3.         int j;
  4.         for(int i=0;i<100000000;++i){
  5.                 j+=i;
  6.         }
  7.         printf("%d\n",j);
  8.         return 0;
  9. }
复制代码
然后编译运行
# g++ m.cpp
# time ./a.out
1021973595

real        0m1.293s
user        0m0.628s
sys        0m0.119s

为什么real不等于user+sys呢? 1.293-0.628-0.119=0.546
剩下的0.546s时间作了什么?

谢谢。

最佳答案

查看完整内容

不一定是阻塞,此进程被调度出执行列表之后的时间(此时该进程没有运行)也算在 time 给出的总时间里面。

论坛徽章:
95
程序设计版块每日发帖之星
日期:2015-09-05 06:20:00程序设计版块每日发帖之星
日期:2015-09-17 06:20:00程序设计版块每日发帖之星
日期:2015-09-18 06:20:002015亚冠之阿尔艾因
日期:2015-09-18 10:35:08月度论坛发贴之星
日期:2015-09-30 22:25:002015亚冠之阿尔沙巴布
日期:2015-10-03 08:57:39程序设计版块每日发帖之星
日期:2015-10-05 06:20:00每日论坛发贴之星
日期:2015-10-05 06:20:002015年亚冠纪念徽章
日期:2015-10-06 10:06:482015亚冠之塔什干棉农
日期:2015-10-19 19:43:35程序设计版块每日发帖之星
日期:2015-10-21 06:20:00每日论坛发贴之星
日期:2015-09-14 06:20:00
2 [报告]
发表于 2013-05-26 09:25 |只看该作者
weichuang02 发表于 2013-05-26 18:27
可是这个printf总不会阻塞0.5s多吧?
谢谢。


不一定是阻塞,此进程被调度出执行列表之后的时间(此时该进程没有运行)也算在 time 给出的总时间里面。

论坛徽章:
4
水瓶座
日期:2013-09-06 12:27:30摩羯座
日期:2013-09-28 14:07:46处女座
日期:2013-10-24 14:25:01酉鸡
日期:2014-04-07 11:54:15
3 [报告]
发表于 2013-05-26 11:46 |只看该作者
因为CPU时间是说进程使用CPU的时间,如果某个API挂起阻塞了一会,那么这个时间不算在任何一个CPU时间里,只会累计到实际运行时间上去。

论坛徽章:
0
4 [报告]
发表于 2013-05-26 18:27 |只看该作者
linux_c_py_php 发表于 2013-05-26 11:46
因为CPU时间是说进程使用CPU的时间,如果某个API挂起阻塞了一会,那么这个时间不算在任何一个CPU时间里,只 ...


可是这个printf总不会阻塞0.5s多吧?
谢谢。

论坛徽章:
4
水瓶座
日期:2013-09-06 12:27:30摩羯座
日期:2013-09-28 14:07:46处女座
日期:2013-10-24 14:25:01酉鸡
日期:2014-04-07 11:54:15
5 [报告]
发表于 2013-05-28 11:30 |只看该作者
weichuang02 发表于 2013-05-26 18:27
可是这个printf总不会阻塞0.5s多吧?
谢谢。


操作系统可能把进程调度了, 导致进程有一段时间没有使用CPU进行运算.
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP