C++詳細講解print緩沖區的刷新
printf緩沖區問題
以下內容在Linux測試,Window中進行試驗時現象可能會有不同。
一.引入
對於printf輸出函數具有緩沖區,是在使用sleep函數測試時發現的。
首先把測試問題復述一下:
簡單寫一個hello world的程序
#include <stdio.h> int main() { printf("hello world\n"); sleep(5); //延遲5秒 printf("hello friend\n"); return 0; }
輸出結果:
hello world 和hello friend的輸出中間間隔瞭5秒
當我們修改一下代碼後:將hello world後的\n換行符刪掉後
#include <stdio.h> int main() { printf("hello world"); sleep(5); //延遲5秒 printf("hello friend\n"); return 0; }
輸出結果:
這個輸出結果是: 光標先閃爍5s然後彈出hello worldhello friend
這裡我們發現就會發現:當我們刪除字符‘\n’,函數sleep不再是語句間延遲,而是變成延遲整個程序。
這裡出現的結果就很詫異 原來就一直沒註意過也沒有想過會存在這個問題 ,下面就深入理解一下printf。
二.深入理解printf
printf是一個行緩沖函數,並不會直接將數據輸出到屏幕,而是先放到緩沖區中,滿足一定的條件後,才會將緩沖區內容輸出。
設置緩沖區是為提高IO速度,減少CUP等待IO而浪費CPU資源。
如下5個條件可以刷新緩沖區:
- 緩沖區寫滿
- 寫入的字符中有‘\n’ , ‘\r’
- 調用fflush手動刷新緩沖區
- 調用scanf要從緩沖區中讀取數據時,也會將緩沖區內的數據刷新
- 程序結束時
1. 緩沖區寫滿
printf函數的緩沖區大小為1024個字節,當超出緩沖區的大小,緩沖區會被刷新,將會打印出結果。
緩沖區大小為1024個字節,這個大小是這樣得出,代碼如下:
#include <stdio.h> #include <stdlib.h> /*argc:命令行輸入參數個數,argv:命令行參數 *argv為字符指針數組,argv[i]為指向第i個命令行參數內容的指針 */ int main(int argc, char **argv){ int i; char a='a'; if(argc != 2) //命令行參數為2,否則出錯 { printf("Usage:%s Number\n",argv[0]); return 0; } for(i=0;i<atoi(argv[1]);i++) //atoi:字符轉化為整數 { printf("%c",a); } while(1); //讓程序一直運行 }
運行結果:
說明:在linux下,printf緩沖區大小為1024字節。while(1)使程序一直運行,當緩沖區未滿時,不會輸出打印。
2. 寫入的字符中有‘\n’,‘\r’
測試代碼:
#include <stdio.h> int main() { printf("hello world\n");// sleep(5); //延遲5秒 printf("hello friend\n"); return 0; }
運行結果:
3. 調用fflush手動刷新緩沖區
測試代碼:
#include<stdio.h> #include<unistd.h> #include<stdlib.h> int main(void) { printf("hello world"); fflush(stdout); sleep(5); exit(0); }
運行過程及結果:
這裡在printf語句結束後,使用fflush強制刷新緩沖區,就先打印出來內容,再執行的 sleep語句。
4. 調用scanf要從緩沖區中讀取數據時,也會將緩沖區內的數據刷新
這個我們可以理解為當我們從鍵盤輸入的時候,就會將數據內的數據自動刷新。
5. 程序結束時
測試代碼:
#include<stdio.h> #include<unistd.h> #include<stdlib.h> int main(void) { printf("hello world"); sleep(5); exit(0); }
運行結果:
到此這篇關於C++詳細講解print緩沖區的刷新的文章就介紹到這瞭,更多相關C++ print緩沖區內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!