你想"启用计时器,运行一些进程,停止计时器".Bash为时间进程提供内置命令,方便调用time.例如,要查找date命令运行所需的时间:
$ time date
Mon Dec 30 12:16:22 PST 2013
real 0m0.003s
user 0m0.000s
sys 0m0.004s
Run Code Online (Sandbox Code Playgroud)
上面的第一行输出是date命令的结果.最后三个来自time告诉您date命令运行的时间(实际)以及在用户模式和系统模式下花费的CPU时间.
time还可以选择显示CPU使用率,计算为用户和系统时间之和除以实时.使用以下环境变量TIMEFORMAT,我们获得看起来像默认值的输出,除了添加一行显示CPU使用百分比:
$ TIMEFORMAT=$'\nreal\t%3lR\nuser\t%3lU\nsys\t%3lS\nCPU\t%P%%'
$ time sleep 1
real 0m1.003s
user 0m0.000s
sys 0m0.000s
CPU 0.00%
Run Code Online (Sandbox Code Playgroud)
该字符串的$'...'格式为,以便将\n其解释为换行符和\t制表符.如果一个人不想要换行符和标签符号,那么就不需要`$'...'.例如,以下内容将生成相同的信息,但在一行中:
TIMEFORMAT='real=%R user=%U sys=%S CPU=%P%%'
Run Code Online (Sandbox Code Playgroud)
在上面的TIMEFORMAT规范中,%P以百分比形式提供CPU使用率.为了说明,我还通过删除"3"和"l"选项简化了上面的最后一个规范; 因此,时间以默认精度和秒显示,而不是以更长的分钟和秒形式显示.有关更多信息,请参阅TIMEFORMAT环境变量的说明man bash.