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 | 無緩衝 |
/* 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