项目日志——输出重定向
前言
在通常情况下,Linux/UNIX每个程序在开始运行的时候,都会自动打开三个标准stream(流),分别为标准输入流stdin(文件描述符0),标准输出流stdout(文件描述符1),标准错误输出流stderr(文件描述符2)。
Linux的本质就是一切皆文件,输入输出设备也是以文件形式存在和管理的。
- stderr是不缓存的,stdout则进行行间缓存,即遇到\n才打印输出。示例如下:
#include <stdio.h>
#include <unistd.h>
int main(int argc, char** argv)
{
for(int i = 0; i < 5; i++){
fprintf(stdout, "This is stdout[%d]", i);
sleep(1);
}
fprintf(stdout,"\n");//stdout
sleep(1);
for(int i = 0; i < 5; i++){
fprintf(stderr, "This is stderr[%d]", i);
sleep(1);
}
sleep(60);
return 0;
}
- 可以发现,第一个循环(stdout)的内容会被一次性打印出来,第二个循环(stderr)的内容会一个一个的打印出来。
重定向
- 有时我们使用printf来打印调试信息,但是如果终端关掉,我们就无法查看到信息了。
- 所以需要我们保存在文件中,以便永久保存。
>
- 将标准输出重定向到文件
./test > test.txt
- 将标准输入和标准出错重定向到文件
./test 1 > testout.txt ./test 2 > testerr.txt
>>
- 以附加方式重定向到文件
- 例如:将标准输入和标准出错以追加的方式重定向到文件中
./test > test1.txt 2>&1
代码中实现重定向操作
#include <stdio.h>
int main(void){
FILE *out = freopen("stdout.txt", "w", stdout);
printf("%s\n", "redirect test");
return 0;
}
- 通常在生产环境下,会将stdin,stdout,stderr这三个流重定向到其他文件。
- 日志中最好加上日期、时间、文件等信息。
- printf涉及到文件,可能会引起IO中断(会进行一系列的系统调用),因此执行printf比一般指令的效率要低很多。一般情况下不建议用printf。