performance - ZSH 的时间命令是否接受任何参数,如 -p?

标签 performance zsh timing

我最近安装了 macOS 10.15 Catalina 的开发者测试版,它默认使用 ZSH 而不是 BASH。

我将 time 作为二进制安装在 /usr/bin/time 中,并使用它为我的一些脚本计时。但是,ZSH 将此作为内置命令。 我的问题是我通常使用 time -p 以我喜欢的方式格式化它的输出,但这在 ZSH 上似乎不可能。

根据人工时间:

     -p      The output is formatted as specified by IEEE Std 1003.2-1992 (``POSIX.2'').

这似乎不适用于 ZSH 的内置,ZSH 似乎也没有使用我安装的 time 二进制文件:

巴什

bash-5.0$ which time
/usr/bin/time
bash-5.0$ time echo hello; echo $?
hello

real    0m0.000s
user    0m0.000s
sys 0m0.000s
0
bash-5.0$ time -p echo hello; echo $?
hello
real 0.00
user 0.00
sys 0.00
0

ZSH

is-mbp-bleggiero% which time
time: shell reserved word
is-mbp-bleggiero% time echo hello; echo $?
hello
0
is-mbp-bleggiero% time -p echo hello; echo $?
zsh: command not found: -p
-p echo hello  0.00s user 0.00s system 74% cpu 0.001 total
127

我觉得这很奇怪;它似乎包括我想要的信息(用户与系统和总计,格式为秒),但它也没有运行命令,而是提示它不存在。

最佳答案

如果你想使用这个选项,你可以调用/usr/bin/time -p,或者=time -p

zsh 内置时间不接受任何选项 (man zshmisc)。

但是您可以使用您想要的格式导出 TIMEFMT,包括使用 \n 的换行符。

echo $TIMEFMT 看看现在是什么

关于performance - ZSH 的时间命令是否接受任何参数,如 -p?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56601663/

相关文章:

performance - NHibernate select指数增长缓慢

jquery窗口调整div高度

Zsh 行编辑器历史过滤

linux - 在 zsh 中按模式拆分

python - Python time.perf_counter() 返回的小数秒到底是多少?

c - C语言的调度例程和时序要求

javascript - jQuery slideToggle() 性能不佳和/或卡住 IE8

autocomplete - zsh 自动完成 ssh 很慢

java - 跨所有方法评估一个线程的性能

mysql - 本地 IP 与环回的数据库访问速度?