当前时区为 UTC + 8 小时



发表新帖 回复这个主题  [ 2 篇帖子 ] 
作者 内容
1 楼 
 文章标题 : bash里面的time结果的real user sys是什么意思?
帖子发表于 : 2009-04-21 14:46 
头像

注册: 2006-07-28 14:58
帖子: 225
地址: 廣州
送出感谢: 0 次
接收感谢: 0 次
比如

tseong@myUbuntu:/tmp$ time dd if=/dev/zero of=/tmp/12m.tmp bs=2k count=2600
记录了 2600+0 的读入
记录了 2600+0 的写出
5324800字节(5.3 MB)已复制,0.0597527 秒,89.1 MB/秒

real 0m0.067s
user 0m0.016s
sys 0m0.032s

我猜测real是实际费时 user是用户态费时 sys是内核态费时

也就是说 real = user + sys + 系统调度损耗时间

不知道正不正确?

tseong@myUbuntu:/tmp$ time sleep 1
real 0m1.004s
user 0m0.000s
sys 0m0.004s

sleep状态是调用某函数被挂起,不再消耗cpu时间对吧?

写了一个忙循环,那为什么sys会有耗时,没执行什么内核代码啊?

代码:
tseong@myUbuntu:/tmp$ cat while.c
#include <stdio.h>

int main(void)
{
   while(1)
      ;
}
tseong@myUbuntu:/tmp$ time ./while


real   0m20.092s
user   0m16.601s
sys   0m0.024s



还有,不知道time怎么得到这些时间的?


页首
 用户资料  
 
2 楼 
 文章标题 : Re: bash里面的time结果的real user sys是什么意思?
帖子发表于 : 2009-04-21 21:31 
头像

注册: 2007-09-14 21:03
帖子: 1143
地址: 浙江
送出感谢: 1
接收感谢: 1
我看了下man看不太懂,,

代码:
time -f "%E real,%U user,%S sys" ls -Fs
这事man中的一个例子
运行的结果是
代码:
happy everyday ~$ time -f "%E real,%U user,%S sys" ls -Fs
bash: -f: command not found

real   0m0.319s
user   0m0.192s
sys   0m0.036s
happy everyday ~$



_________________
Say hello to everyday!


页首
 用户资料  
 
显示帖子 :  排序  
发表新帖 回复这个主题  [ 2 篇帖子 ] 

当前时区为 UTC + 8 小时


在线用户

正在浏览此版面的用户:没有注册用户 和 2 位游客


不能 在这个版面发表主题
不能 在这个版面回复主题
不能 在这个版面编辑帖子
不能 在这个版面删除帖子
不能 在这个版面提交附件

前往 :  
本站点为公益性站点,用于推广开源自由软件,由 DiaHosting VPSBudgetVM VPS 提供服务。
我们认为:软件应可免费取得,软件工具在各种语言环境下皆可使用,且不会有任何功能上的差异;
人们应有定制和修改软件的自由,且方式不受限制,只要他们自认为合适。

Powered by phpBB © 2000, 2002, 2005, 2007 phpBB Group
简体中文语系由 王笑宇 翻译