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

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


參考:http://blog.csdn.net/mycwq/article/details/46554805
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章