bash里面的time结果的real user sys是什么意思?

sh/bash/dash/ksh/zsh等Shell脚本
回复
头像
xxdaystar
帖子: 225
注册时间: 2006-07-28 14:58
来自: 廣州

bash里面的time结果的real user sys是什么意思?

#1

帖子 xxdaystar » 2009-04-21 14:46

比如

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怎么得到这些时间的?
头像
hellojinjie
帖子: 1150
注册时间: 2007-09-14 21:03
来自: 浙江

Re: bash里面的time结果的real user sys是什么意思?

#2

帖子 hellojinjie » 2009-04-21 21:31

我看了下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!
回复