亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

C++詳細(xì)講解print緩沖區(qū)的刷新

 更新時(shí)間:2022年05月21日 10:41:52   作者:Mi?ronin  
這篇文章主要介紹了print緩沖區(qū)刷新問題,實(shí)現(xiàn)代碼簡(jiǎn)單易懂,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,需要的朋友可以參考下

printf緩沖區(qū)問題

以下內(nèi)容在Linux測(cè)試,Window中進(jìn)行試驗(yàn)時(shí)現(xiàn)象可能會(huì)有不同。

一.引入

對(duì)于printf輸出函數(shù)具有緩沖區(qū),是在使用sleep函數(shù)測(cè)試時(shí)發(fā)現(xiàn)的。

首先把測(cè)試問題復(fù)述一下:

簡(jiǎn)單寫一個(gè)hello world的程序

#include <stdio.h>
int main()
{
    printf("hello world\n");
    sleep(5);  //延遲5秒
     printf("hello friend\n");
    return 0;
}

輸出結(jié)果:

hello world 和hello friend的輸出中間間隔了5秒

當(dāng)我們修改一下代碼后:將hello world后的\n換行符刪掉后

#include <stdio.h>
int main()
{
    printf("hello world");
    sleep(5);  //延遲5秒
     printf("hello friend\n");
    return 0;
}

輸出結(jié)果:

這個(gè)輸出結(jié)果是: 光標(biāo)先閃爍5s然后彈出hello worldhello friend

這里我們發(fā)現(xiàn)就會(huì)發(fā)現(xiàn):當(dāng)我們刪除字符‘\n’,函數(shù)sleep不再是語句間延遲,而是變成延遲整個(gè)程序。

這里出現(xiàn)的結(jié)果就很詫異 原來就一直沒注意過也沒有想過會(huì)存在這個(gè)問題 ,下面就深入理解一下printf。

二.深入理解printf

printf是一個(gè)行緩沖函數(shù),并不會(huì)直接將數(shù)據(jù)輸出到屏幕,而是先放到緩沖區(qū)中,滿足一定的條件后,才會(huì)將緩沖區(qū)內(nèi)容輸出。

設(shè)置緩沖區(qū)是為提高IO速度,減少CUP等待IO而浪費(fèi)CPU資源。

如下5個(gè)條件可以刷新緩沖區(qū):

  1. 緩沖區(qū)寫滿
  2. 寫入的字符中有‘\n’ , ‘\r’
  3. 調(diào)用fflush手動(dòng)刷新緩沖區(qū)
  4. 調(diào)用scanf要從緩沖區(qū)中讀取數(shù)據(jù)時(shí),也會(huì)將緩沖區(qū)內(nèi)的數(shù)據(jù)刷新
  5. 程序結(jié)束時(shí)

1. 緩沖區(qū)寫滿

printf函數(shù)的緩沖區(qū)大小為1024個(gè)字節(jié),當(dāng)超出緩沖區(qū)的大小,緩沖區(qū)會(huì)被刷新,將會(huì)打印出結(jié)果。

緩沖區(qū)大小為1024個(gè)字節(jié),這個(gè)大小是這樣得出,代碼如下:

 #include <stdio.h>
 #include <stdlib.h>
 /*argc:命令行輸入?yún)?shù)個(gè)數(shù),argv:命令行參數(shù) 
  *argv為字符指針數(shù)組,argv[i]為指向第i個(gè)命令行參數(shù)內(nèi)容的指針
  */
 int main(int argc, char **argv){ 
     int i;
     char a='a';
     if(argc != 2) //命令行參數(shù)為2,否則出錯(cuò)
     {
         printf("Usage:%s Number\n",argv[0]); 
         return 0;
     }
     for(i=0;i<atoi(argv[1]);i++) //atoi:字符轉(zhuǎn)化為整數(shù)
     {
         printf("%c",a);
     }
     while(1);  //讓程序一直運(yùn)行
 }

運(yùn)行結(jié)果:

說明:在linux下,printf緩沖區(qū)大小為1024字節(jié)。while(1)使程序一直運(yùn)行,當(dāng)緩沖區(qū)未滿時(shí),不會(huì)輸出打印。

2. 寫入的字符中有‘\n’,‘\r’

測(cè)試代碼:

#include <stdio.h>
int main()
{
    printf("hello world\n");//
    sleep(5);  //延遲5秒
     printf("hello friend\n");
    return 0;
}

運(yùn)行結(jié)果:

3. 調(diào)用fflush手動(dòng)刷新緩沖區(qū)

測(cè)試代碼:

#include<stdio.h>
#include<unistd.h>
#include<stdlib.h>
int main(void)
{
    printf("hello world");
    fflush(stdout);
    sleep(5);
    exit(0);
}

運(yùn)行過程及結(jié)果:

這里在printf語句結(jié)束后,使用fflush強(qiáng)制刷新緩沖區(qū),就先打印出來內(nèi)容,再執(zhí)行的 sleep語句。

4. 調(diào)用scanf要從緩沖區(qū)中讀取數(shù)據(jù)時(shí),也會(huì)將緩沖區(qū)內(nèi)的數(shù)據(jù)刷新

這個(gè)我們可以理解為當(dāng)我們從鍵盤輸入的時(shí)候,就會(huì)將數(shù)據(jù)內(nèi)的數(shù)據(jù)自動(dòng)刷新。

5. 程序結(jié)束時(shí)

測(cè)試代碼:

#include<stdio.h>
#include<unistd.h>
#include<stdlib.h>
int main(void)
{
    printf("hello world");
    sleep(5);
    exit(0);
}

運(yùn)行結(jié)果:

到此這篇關(guān)于C++詳細(xì)講解print緩沖區(qū)的刷新的文章就介紹到這了,更多相關(guān)C++ print緩沖區(qū)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • c++網(wǎng)絡(luò)編程下Linux的epoll技術(shù)和Windows下的IOCP模型

    c++網(wǎng)絡(luò)編程下Linux的epoll技術(shù)和Windows下的IOCP模型

    c++ 網(wǎng)絡(luò)編程LINUX-epoll/windows-IOCP下socket opoll函數(shù)用法 優(yōu)于select方法的epoll 以及windows下IOCP 解決多進(jìn)程服務(wù)端創(chuàng)建進(jìn)程資源浪費(fèi)問題,感興趣的小伙伴一起來學(xué)習(xí)吧
    2021-08-08
  • C++ LeetCode1812判斷國(guó)際象棋棋盤格子顏色

    C++ LeetCode1812判斷國(guó)際象棋棋盤格子顏色

    這篇文章主要為大家介紹了C++ LeetCode1812判斷國(guó)際象棋棋盤格子顏色, 有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-12-12
  • OpenCV圖像特征提取之Shi-Tomasi角點(diǎn)檢測(cè)算法詳解

    OpenCV圖像特征提取之Shi-Tomasi角點(diǎn)檢測(cè)算法詳解

    Harris角點(diǎn)檢測(cè)算法就是對(duì)角點(diǎn)響應(yīng)函數(shù)R進(jìn)行閾值處理,Shi-Tomasi原理幾乎和Harris一樣的,只不過最后計(jì)算角點(diǎn)響應(yīng)的公式發(fā)生了變化。本文將和大家詳細(xì)說說Shi-Tomasi角點(diǎn)檢測(cè)算法的原理與實(shí)現(xiàn),需要的可以參考一下
    2022-09-09
  • 詳解C語言中二級(jí)指針與鏈表的應(yīng)用

    詳解C語言中二級(jí)指針與鏈表的應(yīng)用

    對(duì)于初學(xué)者而言,有很多地方肯定是費(fèi)解的。比如函數(shù)的參數(shù)列表的多樣化,動(dòng)態(tài)分配內(nèi)存空間函數(shù)malloc等,其實(shí)這些知識(shí)和指針聯(lián)系緊密,尤其是二級(jí)指針,快跟隨小編來學(xué)習(xí)一下吧
    2022-07-07
  • C語言數(shù)據(jù)(整數(shù)、浮點(diǎn)數(shù))在內(nèi)存中的存儲(chǔ)

    C語言數(shù)據(jù)(整數(shù)、浮點(diǎn)數(shù))在內(nèi)存中的存儲(chǔ)

    之前對(duì)c語言數(shù)據(jù)存儲(chǔ)一直不太明白,最近仔細(xì)研究了一番,所以下面這篇文章主要給大家介紹了關(guān)于C語言數(shù)據(jù)(整數(shù)、浮點(diǎn)數(shù))在內(nèi)存中存儲(chǔ)的相關(guān)資料,需要的朋友可以參考下
    2021-06-06
  • Vue自定義指令最佳實(shí)踐教程分享

    Vue自定義指令最佳實(shí)踐教程分享

    Vue?3?顯著增強(qiáng)了自定義指令的功能,使其封裝更加靈活和易用,本文將分為基礎(chǔ)和進(jìn)階兩部分,介紹如何實(shí)現(xiàn)常用的自定義指令,并提供最佳的項(xiàng)目組織方式,需要的朋友可以參考下
    2024-12-12
  • 深入探討Linux靜態(tài)庫與動(dòng)態(tài)庫的詳解(一看就懂)

    深入探討Linux靜態(tài)庫與動(dòng)態(tài)庫的詳解(一看就懂)

    本篇文章是對(duì)Linux靜態(tài)庫與動(dòng)態(tài)庫進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下
    2013-05-05
  • C/C++?引用作為函數(shù)的返回值方式

    C/C++?引用作為函數(shù)的返回值方式

    這篇文章主要介紹了C/C++?引用作為函數(shù)的返回值方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-07-07
  • 使用C語言實(shí)現(xiàn)從avi視頻中提取圖片

    使用C語言實(shí)現(xiàn)從avi視頻中提取圖片

    這篇文章主要為大家詳細(xì)介紹了如何使用C語言實(shí)現(xiàn)從avi視頻中提取圖片,文中的示例代碼簡(jiǎn)潔易懂,具有一定的借鑒價(jià)值,有需要的小伙伴可以參考下
    2023-10-10
  • C語言調(diào)用SQLite數(shù)據(jù)庫實(shí)現(xiàn)數(shù)據(jù)增刪改查

    C語言調(diào)用SQLite數(shù)據(jù)庫實(shí)現(xiàn)數(shù)據(jù)增刪改查

    SQLite是一種輕量級(jí)的關(guān)系型數(shù)據(jù)庫管理系統(tǒng),是一個(gè)開源的、零配置的、服務(wù)器端的、自包含的、零管理的、事務(wù)性的SQL數(shù)據(jù)庫引擎,本文主要介紹了如何調(diào)用SQLite數(shù)據(jù)庫實(shí)現(xiàn)數(shù)據(jù)增刪改查,需要的可以參考一下
    2023-08-08

最新評(píng)論