溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

C語言之scanf函數(shù)

發(fā)布時間:2020-07-20 19:55:40 來源:網(wǎng)絡(luò) 閱讀:161 作者:師趣妮 欄目:編程語言
  • scanf()--------按照指定格式接受用戶輸入(工作原理理解要點(diǎn):正則表達(dá)式)

    格式:

int num1= -1,num2 = -1;
scanf("%i[間隔符]%i",&num1,&num2);    
/*
    %var指向變量在內(nèi)存的詳細(xì)地址,獲得用戶輸入,直接將值寫進(jìn)指定內(nèi)存空間中;
    [間隔符]可省略,省略后,C語言默認(rèn)以空白字符分隔用戶輸入的變量值;如果不為空,則要求用戶必須按照指定格式輸入,否則變量未必能夠全部接受到用戶輸入的值;
    C語言默認(rèn)以\n即換行符結(jié)束輸入;
    C語言默認(rèn)%i此類的占位符可以進(jìn)行無限匹配,直至匹配失敗,默認(rèn)用戶變量值輸入結(jié)束;
    接收用戶輸入過程:當(dāng)C獲得用戶從鍵盤的輸入后,首先會將輸入內(nèi)容保存到一個輸入緩存區(qū)內(nèi),強(qiáng)調(diào)保存到輸入緩存區(qū)的內(nèi)容包括用戶輸入的所有字符,當(dāng)然空白字符也包括在其中,
        然后會以格式控制字符串匹配緩存區(qū)內(nèi)的內(nèi)容.如上例,首先會%i匹配緩存區(qū)內(nèi)的內(nèi)容,當(dāng)%i進(jìn)行匹配的時候,如間隔符為空,其首先遇到空白字符時,會自動忽略,再次遇到空白
        字符,則結(jié)束num1的值得獲取,開始先一個變量的獲取;當(dāng)間隔符不為空,%i會匹配到間隔符時,結(jié)束獲取,開始下一個變量的獲取.
*/
int num = -1;
char char_value;
scanf("%i[間隔符]%c",&num,&char_value);
/*
    %c可以匹配任何單字節(jié)字符,其中也包括空白字符;
    所以當(dāng)將用戶輸入存入緩存區(qū)后,如果間隔符為空,C默認(rèn)以空白字符分隔不同變量輸入的值.首先C會以%i匹配緩存內(nèi)的內(nèi)容,在沒有匹配到值之前,遇到的空白字符皆會自動忽略,直至匹
        配到值,再次遇到空白字符是,結(jié)束第一個變量值得獲取,也即以為除了第一個變量值之外,變量值之后的空白字符和第二個變量的值仍然保存在空白字符區(qū)內(nèi),C會%c匹配剩余字符,
        由于空白字符也是一個字符,且%c只能匹配一個單字節(jié)字符,所以%c匹配一個空白字符后,整個匹配過程結(jié)束,而%c卻沒有匹配到自己本應(yīng)匹配到的值.解決辦法:輸入的兩個變量的值
        緊挨不留空白;
*/
printf("請輸入一個數(shù)字:\n");
int num = -1;
scanf("%i",&num);
prinf("請輸入一個字符:\n");
char char_value;
scanf("%c",&char_value);
printf("num = %i,%char_value = %c",num,char_value);
/*
    當(dāng)按照如上格式,分兩次分別獲得輸入,且后面的一次輸入為字符時,結(jié)果就會發(fā)現(xiàn),第二個scanf函數(shù)根本就沒有運(yùn)行,直接就輸出了,且char_value的值為空;
    其原因在與當(dāng)緩存區(qū)內(nèi)有值時,C就不會要求用戶輸入,直接拿緩存區(qū)內(nèi)的值去和%c進(jìn)行匹配,由于在獲取完第一次輸入后,緩存區(qū)內(nèi)至少還有一個\n,所以%c與\n匹配成功,直接進(jìn)行輸出,
    不再需要用戶輸入.當(dāng)然,當(dāng)?shù)诙潍@得的輸入為整型,就不存在上述過程了.
*/



向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI