STDOUT和STDERR,以及它们的重定向

它们都是Linux系统的标准文件

在Linux系统中,有3个标准的文件,它们分别占据了文件编号:

  1. 0,STDIN,标准输入文件。
  2. 1,STDOUT,标准输出文件。
  3. 2,STDERR,标准错误文件。

它们仨在Linux系统中,都会有着具体的文件描述符限定着它们的特性,都对应着特定的输入输出设备:
img

其中,STDOUT与STDERR都会对应着输出设备,而且如果不重定向的话,它们的输出都会输出到屏幕(在Linux系统中,就是一种FrameBuffer的设备),所以有不少人容易把它们搞混。

STDOUT与STDERR的区别

我们应看到,它俩主要有两份点不同:

  1. 如果指定了输出是某个文件,则STDOUT的输出会到这个文件,而STDERR仍然继续输出到屏幕。
  2. STDOUT是行缓冲的,也就是只有有换行符时,其上的内容才会到指定的文件(不管是屏幕这个设备文件,还是其它的一般文件);而STDERR则不会有缓冲,所以有字节内容,它就会输出。

下面一段C的代码,大家可以试Run一下,来感受STDOUT缺省输出与重定向后的区别:

char zf[20] =  "this is a test!" ;
FILE* aabb;
aabb = fopen("abc.txt","w");
printf("hello,world");
if(aabb!=NULL)
    fprintf(aabb,"Hello%s\n",zf);

下面的两条语句,则可以用来检查STDOUT的缓冲,和STDERR的无缓冲的设计:

fprintf(stdout,"Hello ");
fprintf(stderr,"World!");

我们可以在屏幕上看到上面两条紧挨着的语句输出:world!Hello

STDERR可以重定向到一般文件吗

程序缺省会把错误信息输出到STDERR,也就是会输出到屏幕上。通过将STDOUT重定向到一般文件,可以很好地将错误日志与程序的一般运行日志,相区别开来,可以让程序员更好地聚焦在错误日志。但有时候错误日志太多,会在屏幕上有太多的错误信息,程序员想要翻阅之前的错误,或者寻找错误的根源,直接在屏幕上查找,则非常不方便。有没有办法,也将STDERR重定向到一般的文件?

答案是肯定的。下面就来讲讲通过命令行,是如何实现STDERR的重定向。

命令行中设置重定向时,会有两种重定向符,它们是:

  • > 以擦写的模式重定向至…
  • >> 以追加的模式重定向至…

那么,想要将STDERR重新定向到一般文件,可以参考以下命令格式

cmd &2 > ./error.txt

上面命令行中的2,就是代表STDERR的文件索引号,就是指定对STDERR进行重定向;而&符号没任何实际意义,只是以至区分,代表后面的符号是要设置重定向用的,而不是某个文件的名字。

猜你喜欢

转载自blog.csdn.net/DongAoTony/article/details/123949602