我们在调试程序或者打印日志时经常会遇到重定向的问题,而有时候会遇到重定向无效的问题,下面给一个简单的例子,首先写一个简单的test.c
#include <stdio.h>int main(){fprintf(stdout, "hello\n");fprintf(stderr, "world\n");return 0;
}
编译生成可执行程序test,如果执行:
./test > log.txt
会有打印
world
而hello的内容会跑到log.txt里面,同样如果我们写个脚本运行:
output=`./test`
echo "*************************"
echo $output
打印结果如下:
world
*************************
hello
可以看到,hello跑到了output变量里面,而world没有,这是什么原因呢,显然关键在stdout和stderr。在linux系统,一旦创建一个进程,那么与之对应的会有三个数据流:stdin,stdout和stderr,对应的会创建三个文件:stdin,标准输入文件,通常对应着终端的键盘。stdout,标准输出文件ÿ