通常,stderr和stdout被用來輸出內容顯示到屏幕,但是,有時候我們需要把這些信息寫到指定的文件,方便隨時查閱。最簡單的實現方式就是,把 stderr/stdout 的輸出重定向到文件。
stderr/stdout 重定向到文件
這裡以stderr代碼說明。
#include <stdio.h>
#include <stdlib.h>
int main( void )
{
FILE *stream = freopen( "freopen.out", "w", stderr );
if( stream == NULL )
fprintf( stdout, "error on freopen\n" );
else
{
fprintf( stdout, "successfully reassigned\n" ); fflush( stdout );
fprintf( stream, "This will go to the file 'freopen.out'\n" );
fprintf( stderr, "Also you can do it like this!\n" );
fclose( stream );
}
// windwos下讀取文件 freopen.out
system( "type freopen.out" );
getchar();
return 0;
}
執行結果如下,
stderr與stdout的區別
stdout(標准輸出),輸出方式是行緩沖。輸出的字符會先存放在緩沖區,等按下回車鍵時才進行實際的I/O操作。
stderr(標准出錯),是不帶緩沖的,這使得出錯信息可以直接盡快地顯示出來。
關於緩沖的說明:
類型 說明 輸出情況 滿緩沖 I/O操作只有在緩沖區被填滿之後才會進行 1.緩沖區滿 2.刷出數據 (fflush) 3.關閉文件 (fclose) 行緩沖 通常只有遇到換行符時,才會執行實際的I/O操作;但緩沖區滿也會強制執行 1.遇到換行符 2.緩沖區滿 3.刷出數據 (fflush) 4.關閉文件 (fclose) 無緩沖 不緩存,直接進行I/O操作 直接輸出然而就緩沖來說,stdout與stderr沒有絕對的區別,因為緩沖類型可以設定。這裡要借助 setvbuf() 或 setbuf() 函數。
#include <stdio.h>
#include <stdlib.h>
int main( void )
{
char buf[512] = {0};
setbuf(stderr, buf);
fprintf(stderr, "It is error 1\n");
printf("echo 1\n");
fprintf(stderr, "It is error 2\n");
printf("echo 2\n");
fprintf(stderr, "It is error 3\n");
fflush(stderr);
getchar();
return 0;
}
運行結果如下:
這樣,我們就可以定義緩沖區大小。緩沖區默認大小由 stdio.h 頭文件中的宏 BUFSIZ 定義,是512字節。另外,查閱一些資料說最小不能低於256字節,但測試例子沒有這個問題(暫時沒有深究)。
setvbuf() 與 setbuf()
setvbuf() 函數原型如下:
int setvbuf ( FILE * stream, char * buffer, int mode, size_t size );
setbuf() 可以當作是調用setvbuf(stream, buf, buf ? _IOFBF : _IONBF, BUFSIZE);
其中, mode是聲明緩沖的類型,如下幾個:
_IOFBF
滿緩沖
_IOLBF
行緩沖
_IONBF
無緩沖
size是緩沖區大小,單位字節。
/* setvbuf example */
#include <stdio.h>
int main ()
{
FILE *pFile=fopen ("myfile.txt","w");
setvbuf ( pFile , NULL , _IOFBF , 1024 );
// File operations here
fclose (pFile);
return 0;
}