C語(yǔ)言清除scanf()緩存的案例講解
又重新過(guò)一遍C語(yǔ)言,感覺(jué)每次重學(xué)C語(yǔ)言都有不同的感受,遇到了一個(gè)問(wèn)題,就是scanf()這個(gè)問(wèn)題,其實(shí)細(xì)究起來(lái),也有很多可以值得深挖的,實(shí)際上每次細(xì)細(xì)的挖掘的話,都是對(duì)C語(yǔ)言的更透徹的認(rèn)識(shí).
那么下面我就對(duì)scanf()中清除輸入緩沖區(qū)的方法講解:
應(yīng)用場(chǎng)景:我們使用多個(gè)scanf()的時(shí)候,如果輸入緩沖區(qū)還有數(shù)據(jù)的話,那么scanf()就不會(huì)詢問(wèn)用戶輸入,而是直接就將輸入緩沖區(qū)的內(nèi)容拿出來(lái)用了,這就導(dǎo)致了前面的錯(cuò)誤影響到后面的內(nèi)容,為了隔離這種問(wèn)題,
總的思想:通過(guò)各種方法將輸入緩沖區(qū)的內(nèi)容讀出來(lái).
(1)清除緩存的函數(shù)是:
void safe_flush(FILE *fp)
{
int ch;
while( (ch = fgetc(fp)) != EOF && ch != '\n' );
}
(2)然后我們?cè)谑褂玫臅r(shí)候,直接調(diào)用就可以了:
scanf("%d",&k);
safe_flush(stdin);
這樣就可以清除緩存帶來(lái)的問(wèn)題了!
(3)案例演示
a.當(dāng)我們不清除scanf所帶來(lái)的危害的時(shí)候:
#include<stdio.h>
#include<string.h>
int main()
{
int k;
printf("請(qǐng)輸入你的秘鑰:(整數(shù))");
scanf("%d",&k);
char c;
printf("請(qǐng)輸入一個(gè)字符:");
c = getchar();
printf("%d ",k);
printf("%c ",c);
}
我們發(fā)現(xiàn) 我們輸入一個(gè)整數(shù)的時(shí)候,就自動(dòng)結(jié)束程序了,并且將輸入的數(shù)值作為緩存給了字符c

然后我們清除緩存:
#include<stdio.h>
#include<string.h>
//用于清除回車鍵緩存的影響
void safe_flush(FILE *fp)
{
int ch;
while( (ch = fgetc(fp)) != EOF && ch != '\n' );
}
int main()
{
int k;
printf("請(qǐng)輸入你的秘鑰:(整數(shù))");
scanf("%d",&k);
safe_flush(stdin);
char c;
printf("請(qǐng)輸入一個(gè)字符:");
c = getchar();
printf("%d ",k);
printf("%c ",c);
}
當(dāng)我們輸入整數(shù)之后,提示我們輸入字符,顯然消除了緩存

ok!
總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對(duì)腳本之家的支持。如果你想了解更多相關(guān)內(nèi)容請(qǐng)查看下面相關(guān)鏈接
相關(guān)文章
C語(yǔ)言 動(dòng)態(tài)分配數(shù)組案例詳解
這篇文章主要介紹了C語(yǔ)言 動(dòng)態(tài)分配數(shù)組案例詳解,本篇文章通過(guò)簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下2021-08-08
C\C++實(shí)現(xiàn)讀寫二進(jìn)制文件的方法詳解
這篇文章主要為大家詳細(xì)介紹了C\C++實(shí)現(xiàn)讀寫二進(jìn)制文件的方法,文中的示例代碼講解詳細(xì),具有一定的借鑒價(jià)值,感興趣的小伙伴可以了解一下2023-03-03
C語(yǔ)言中查詢進(jìn)程信號(hào)是否被遮罩或擱置的簡(jiǎn)單方法
這篇文章主要介紹了C語(yǔ)言中查詢進(jìn)程信號(hào)是否被遮罩或擱置的簡(jiǎn)單方法,包括sigprocmask函數(shù)和sigpending函數(shù)的簡(jiǎn)介,需要的朋友可以參考下2015-09-09
求素?cái)?shù),用vector存儲(chǔ)的實(shí)現(xiàn)方法
本篇文章是對(duì)求素?cái)?shù),用vector存儲(chǔ)的實(shí)現(xiàn)方法進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-05-05

