果洛电子商务网站建设哪家快/做互联网项目怎么推广
文章目录
- 项目日志
- stdin(标准输入), stdout(标准输出), stderr(标准出错)
- 重定向
- 箭头实现重定向
- 代码实现重定向
项目日志
stdin(标准输入), stdout(标准输出), stderr(标准出错)
在通常情况下,Linux/UNIX每个程序在开始运行的时刻,都会打开3个已经打开的stream. 分别用来输入,输出,打印诊断和错误信息。通常他们会被连接到用户终端。这3个句柄的类型为指向FILE的指针。他们在程序开始启动后,stdin, stdout, and stderr 的文件描述符是 0, 1和2,其它的文件描述符则排在其后。
Linux的本质就是一切皆文件,输入输出设备也是以文件形式存在和管理的。
注意:stderr是不缓存的,stdout则进行行间缓存。接下来我们看下行间缓存的效果,请参考以下代码:
- strout:会把之前的内容进行缓存,直到遇到换行符一起输出
- stderr:直接输出
- 如果不理解,就把下面两个代码运行一下就明白了
#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);}putchar('\n');for(int i = 0; i < 5; i++){fprintf(stderr, "This is stderr[%d]", i);sleep(1);}return 0;
}
比较如下代码:
- 上面两端代码就是在打印的时候加上了"\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]\n", i);sleep(1);}sleep(1);for(int i = 0; i < 5; i++){fprintf(stderr, "This is stderr[%d]\n", i);sleep(1);}return 0;
}
- 思考:很多时候我们会用printf打印信息来调试程序,但是如果终端关掉了,那怎么显示printf的调试信息呢?
程序员就获取不到调试信息了,所以把调试信息重定向到一个文件中可以永久保存
重定向
箭头实现重定向
我们来先看这段程序(文件名demo1.c):
#include <stdio.h>int main(int argc, char** argv)
{printf("welcome to qiniu!\n");fprintf(stdout, "I am cui!\n");perror("are you all ready?\n");fprintf(stderr, "cui always stay with you!\n");return 0;
}
- 我们试试下面不同的运行方式,
- 标准输出重定向到文件: ./test > test.txt
标准输出和标准出错重定向到文件:./test > test.txt 2>&1
每一次重定向,输出到文件中,都会从开端写入数据,导致之前的调试信息被覆盖,如果想保存之前的调试信息,那么就只能在重定向文件中追加调试信息 这里把 ‘>’ 换成 ‘>>’ 就可以了
代码实现重定向
另外我们还可以在代码中实现重定向,比如:
#include <stdio.h>int main(void)
{// 重新打开 把stdout以写的方式指向stdout.txtFILE *out = freopen("stdout.txt", "w", stdout);printf("%s\n", "hello verybody!!!");return 0;
}
总的来说,stdin,stdout和stderr还是和终端有密切关系,通常在生产环境时,会将这3个流重定向到其它文件。
如果我们实在要用printf或者fprintf去生成日志的话,最好还是加上这些信息,FILE LINE FUNCTION, DATE, TIME。
当然我们一定要明白,printf设计到文件,这会引起IO中断,因此执行printf比一般的指令的效率要低很多。