该脚本是:
#!/bin/bash
echo "recursive c"
for ((i=0;i<=20;i+=1)); do
time ./recursive
done
但如果我像这样运行它:
script.sh >> temp.txt
解决方法:
将STDERR重定向到STDOUT:
script.sh >> temp.txt 2>&1
或者如果使用bash 4.0:
$script.sh &>> temp.txt
(感谢第二种形式去评论者ephemient.我无法验证,因为我有一个早先的bash.)
我的测试令人惊讶:
$time sleep 1 > /dev/null 2>&1
real 0m1.036s
user 0m0.002s
sys 0m0.032s
问题是重定向是作为定时命令的一部分包含的.以下是此测试的解决方案:
$(time sleep 1) > /dev/null 2>&1
我不认为这是你问题的一部分,但似乎值得一提.
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。