歡迎來到Linux教程網
Linux教程網
Linux教程網
Linux教程網
Linux教程網 >> Linux編程 >> Linux編程 >> C++ stderr/stdout 重定向到文件

C++ stderr/stdout 重定向到文件

日期:2017/3/1 9:28:18   编辑:Linux編程

通常,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;
}

Copyright © Linux教程網 All Rights Reserved