c語言scanf解釋,c語言scanf定義

本文目錄一覽:

C中scanf是什麼意思?

scanf()函數釋疑(上)

一、 序言

scanf()函數是所有C語言學習者在學習C語言過程中所遇到的第二個函數(第一個函數是printf(),Brian W.Kerninghan Dennis M.Ritchie的“hello,world”程序基本上是所有的C語言學習者第一個範例),所以scanf()函數應當是C學習者能熟練運用的一個函數,但有很多初學者對此函數不能很好的運用,在實際編程中錯誤使用scanf()函數,導至程序產生某種錯誤不能正常運行,以至產生“scanf()函數有BUG”,“scanf()函數無用論”等等錯誤觀點。

本文結合筆者在編程實踐中及論壇上網友所遇到的問題作一釋疑,但筆者水平有限(菜鳥級),難免有謬誤之處,還望達人指點一二。(Email:knocker.k@126.com)

本文分上,下兩篇講述了C語言中的scanf()函數的用法,重點闡述使用scanf()函數過程中出現的常見錯誤及對策。當然,文中某些解決方法,均可以採用其他函數和方法來更好地解決,但本文僅限討論scanf()函數本身。

上篇,詳細介紹了scanf()函數控制串的構成。下篇,用實際例程介紹scanf()函數控制串運用出現的常見錯誤及對策技巧。

二、 scanf()函數的控制串

函數名: scanf

功 能: 執行格式化輸入

用 法: int scanf(char *format[,argument,…]);

scanf()函數是通用終端格式化輸入函數,它從標準輸入設備(鍵盤) 讀取輸入的信息。可以讀入任何固有類型的數據並自動把數值變換成適當的機內格式。

其調用格式為: scanf(“格式化字符串”,地址表);

scanf()函數返回成功賦值的數據項數,出錯時則返回EOF。

其控制串由三類字符構成:

1。格式化說明符;

2。空白符;

3。非空白符;

(A) 格式化說明符

格式字符 說明

%a 讀入一個浮點值(僅C99有效)

%A 同上

%c 讀入一個字符

%d 讀入十進制整數

%i 讀入十進制,八進制,十六進制整數

%o 讀入八進制整數

%x 讀入十六進制整數

%X 同上

%c 讀入一個字符

%s 讀入一個字符串

%f 讀入一個浮點數

%F 同上

%e 同上

%E 同上

%g 同上

%G 同上

%p 讀入一個指針

%u 讀入一個無符號十進制整數

%n 至此已讀入值的等價字符數

%[] 掃描字符集合

%% 讀%符號

附加格式說明字符表

修飾符 說明

L/l 長度修飾符 輸入”長”數據

h 長度修飾符 輸入”短”數據

W 整型常數 指定輸入數據所佔寬度

* 星號 空讀一個數據

hh,ll同上h,l但僅對C99有效。

(B) 空白字符

空白字符會使scanf()函數在讀操作中略去輸入中的一個或多個空白字符,空白符可以是space,tab,newline等等,直到第一個非空白符出現為止。

(C) 非空白字符

一個非空白字符會使scanf()函數在讀入時剔除掉與這個非空白字符相同的字符。

註:scanf()控制串知識就介紹到這裡(應該比較齊全了^_^),如有遺漏下次補上。下面將結合實際例程,一一闡述.

三、 scanf()函數的控制串的使用

例1.

#include “stdio.h”

int main(void)

{

int a,b,c;

scanf(“%d%d%d”,a,b,c);

printf(“%d,%d,%d\n”,a,b,c);

return 0;

}

運行時按如下方式輸入三個值:

3□4□5 ↙(輸入a,b,c的值)

3,4,5 (printf輸出的a,b,c的值)

(1) a、b、c中的是地址運算符,分別獲得這三個變量的內存地址。

(2) “%d%d%d”是按十進值格式輸入三個數值。輸入時,在兩個數據之間可以用一個或多個空格、tab鍵、回車鍵分隔。

以下是合法輸入方式:

① 3□□4□□□□5↙

② 3↙

4□5↙

③ 3(tab鍵)4↙

5↙

例2.

#include “stdio.h”

int main(void)

{

int a,b,c;

scanf(“%d,%d,%d”,a,b,c);

printf(“%d,%d,%d\n”,a,b,c);

return 0;

}

運行時按如下方式輸入三個值:

3,4,5 ↙(輸入a,b,c的值)

或者

3,□4,□5 ↙(輸入a,b,c的值)

3,□□□4,□5 ↙(輸入a,b,c的值)

……

都是合法的,但是”,”一定要跟在數字後面,如:

3□,4,□5 ↙就非法了,程序出錯。(解決方法與原因後面講)

再如:

1、sacnf()中的變量必須使用地址。

int a, b;

scanf(“%d%d”,a,b); //錯誤

scanf(“%d%d”,a,b);

2、scanf()的格式控制串可以使用其它非空白字符,但在輸入時必須輸入這些字符。

例:

scanf(“%d,%d”,a,b);

輸入: 3,4 ↙(逗號與”%d,%d”中的逗號對應)

scanf(“a=%d,b=%d”,a,b);

輸入: a=3,b=4 ↙(”a=”,”b=”,逗號與”%d,%d”中的”a=”,”b=”及逗號對應)

3、在用”%c”輸入時,空格和“轉義字符”均作為有效字符。

例:

scanf(“%c%c%c”,c1,c2,c3);

輸入:a□b□c↙

結果:a→c1,□→c2,b→c3 (其餘被丟棄)

scanf()函數接收輸入數據時,遇以下情況結束一個數據的輸入:(不是結束該scanf函數,scanf函數僅在每一個數據域均有數據,並按回車後結束)。

① 遇空格、“回車”、“跳格”鍵。

② 遇寬度結束。

③ 遇非法輸入。

上篇就寫到這裡吧,第三小節的例程”抄”自網上的一個教程(原因有二:一,可以少打不少字。二,□↙我不知道怎麼打。^_^),並刪去其中的錯誤之處.這裡也順便提醒本文讀者一句:凡事要親力而為,即使是經典的書籍也不免有疏漏之處,所以,用編譯器說話是最可靠的,是對是錯請編譯器告訴你。

scanf()函數釋疑(下)

在上篇我已經表達了兩個觀點,這裡再重申一次:1。本文僅對scanf()函數控制串運用進行探討,本文所有例程並不構成編程建議。2。凡事要親力而為,不同平台不同編譯器,可能會有不同結果。本文所有例程均在WIN-TC+windows Me下調試。

四、 scanf()函數控制串運用出現的常見錯誤及對策技巧

問題一: 程序編譯通過,但運行錯誤提示如下:

scanf : floating point formats not linked

Abnormal program termination

出錯示例程序:

#include stdio.h

int main(void)

{

int i,j ;

float s[3][3];

/*這裡*/

for(i=0;i3;i++)

for(j=0;j3;j++)

scanf(“%f”,s[i][j]);

for(i=0;i3;i++)

for(j=0;j3;j++)

printf(“%f”,s[i][j]);

}

這實際上是個與本文主題無關的問題,也是與scanf()函數無關,是編譯器的問題。

原因很明確:沒有鏈接浮點庫。早期系統內存資源緊張,多維浮點數組佔用內存量大(一維浮點數組就沒有此問題),因此TC在編譯時盡量不加入無關的部分,在沒發現需要浮點轉換程序時,就不在可執行程序中安裝這個部分。而有時TC又不能正確識別實際上確實需要做浮點轉換,因此就會出現上面錯誤。

解決的方法:告訴TC需要做浮點數的輸入轉換。將以下語句加入上面程序中標有/*這裡*/處。

方法一: float c;

scanf(“%f”,c);

方法二: float c,*t;//此處手誤,現已更正t===》*t;

t=c;

…..

也就是說,編譯器只要有浮點轉換的線索,TC就會把浮點轉換連上,所以一般大一點的程序里的就會有浮點變量反而沒有此問題。

但問題到此並沒結束,我在上面有句“一維浮點數組就沒有此問題”,那麼我們來看看這樣行不行:

#include stdio.h

int main(void)

{

int i,j ;

float s[3][3],*ptr;

ptr=s[0][0];

for(i=0;i3;i++)

for(j=0;j3;j++)

scanf(“%f”,ptr+i*3+j);

for(i=0;i3;i++)

for(j=0;j3;j++)

printf(“%7.2f\n”,s[i][j]);

}

這樣我們就把多維浮點數組降為一維浮點數組來處理,調試一下,程序運行正常。這說明TC編譯器僅在處理多維浮點數組(結構體)有此“未鏈接浮點庫”的問題。

問題二:scanf()函數不能正確接受有空格的字符串?如: I love you!

#include stdio.h

int main()

{

char str[80];

scanf(“%s”,str);

printf(“%s”,str);

return 0;

}

輸入:I live you!

輸出:I

scanf()函數接收輸入數據時,遇以下情況結束一個數據的輸入:(不是結束該scanf函數,scanf函數僅在每一個數據域均有數據,並按回車後結束)。

① 遇空格、“回車”、“跳格”鍵。

② 遇寬度結束。

③ 遇非法輸入。

所以,上述程序並不能達到預期目的,scanf()掃描到”I”後面的空格就認為對str的賦值結束,並忽略後面的”love you!”.這裡要注意是”love you!”還在鍵盤緩衝區(關於這個問題,網上我所見的說法都是如此,但是,我經過調試發現,其實這時緩衝區字符串首尾指針已經相等了,也就是說緩衝區清空了,scanf()函數應該只是掃描stdin流,這個殘存信息是在stdin中)。我們改動一下上面的程序來驗證一下:

#include stdio.h

int main()

{

char str[80];

char str1[80];

char str2[80];

scanf(“%s”,str);/*此處輸入:I love you! */

printf(“%s”,str);

sleep(5);/*這裡等待5秒,告訴你程序運行到什麼地方*/

scanf(“%s”,str1);/*這兩句無需你再輸入,是對鍵盤盤緩衝區再掃描 */

scanf(“%s”,str2);/*這兩句無需你再輸入,是對鍵盤盤緩衝區再掃描 */

printf(“\n%s”,str1);

printf(“\n%s”,str2);

return 0;

}

輸入:I love you!

輸出:I

love

you!

好了,原因知道了,那麼scanf()函數能不能完成這個任務?回答是:能!別忘了scanf()函數還有一個 %[] 格式控制符(如果對%[]不了解的請查看本文的上篇),請看下面的程序:

#include “stdio.h”

int main()

{

char string[50];

/*scanf(“%s”,string);不能接收空格符*/

scanf(“%[^\n]”,string);

printf(“%s\n”,string);

return 0;

}

問題三:鍵盤緩衝區殘餘信息問題

#include stdio.h

int main()

{

int a;

char c;

do

{

scanf(“%d”,a);

scanf(“%c”,c);

printf(“a=%d c=%c\n”,a,c);

/*printf(“c=%d\n”,c);*/

}while(c!=’N’);

}

scanf(“%c”,c);這句不能正常接收字符,什麼原因呢?我們用printf(“c=%d\n”,c);將C用int表示出來,啟用printf(“c=%d\n”,c);這一句,看看scanf()函數賦給C到底是什麼,結果是 c=10 ,ASCII值為10是什麼?換行即\n.對了,我們每擊打一下”Enter”鍵,向鍵盤緩衝區發去一個“回車”(\r),一個“換行”(\n),在這裡\r被scanf()函數處理掉了(姑且這麼認為吧^_^),而\n被scanf()函數“錯誤”地賦給了c.

解決辦法:可以在兩個scanf()函數之後加個fflush(stdin);,還有加getch(); getchar();也可以,但是要視具體scanf()語句加那個,這裡就不分析了,讀者自己去摸索吧。但是加fflush(stdin);不管什麼情況都可行。

函數名: fflush

功 能: 清除一個流

用 法: int fflush(FILE *stream);

#include stdio.h

int main()

{

int a;

char c;

do

{

scanf(“%d”,a);

fflush(stdin);

scanf(“%c”,c);

fflush(stdin);

printf(“a=%d c=%c\n”,a,c);

}while(c!=’N’);

}

這裡再給一個用“空格符”來處理緩衝區殘餘信息的示例:

運行出錯的程序:

#include stdio.h

int main()

{

int i;

char j;

for(i = 0;i 10;i++)

{

scanf(“%c”,j);/*這裡%前沒有空格*/

}

}

使用了空格控制符後:

#include stdio.h

int main()

{

int i;

char j;

for(i = 0;i 10;i++)

{

scanf(” %c”,j);/*注意這裡%前有個空格*/

}

}

可以運行看看兩個程序有什麼不同。

問題四 如何處理scanf()函數誤輸入造成程序死鎖或出錯?

#include stdio.h

int main()

{

int a,b,c; /*計算a+b*/

scanf(“%d,%d”,a,b);

c=a+b;

printf(“%d+%d=%d”,a,b,c);

}

如上程序,如果正確輸入a,b的值,那麼沒什麼問題,但是,你不能保證使用者每一次都能正確輸入,一旦輸入了錯誤的類型,你的程序不是死鎖,就是得到一個錯誤的結果,呵呵,這可能所有人都遇到過的問題吧?

解決方法:scanf()函數執行成功時的返回值是成功讀取的變量數,也就是說,你這個scanf()函數有幾個變量,如果scanf()函數全部正常讀取,它就返回幾。但這裡還要注意另一個問題,如果輸入了非法數據,鍵盤緩衝區就可能還個有殘餘信息問題。

正確的例程:

#include stdio.h

int main()

{

int a,b,c; /*計算a+b*/

while(scanf(“%d,%d”,a,b)!=2)fflush(stdin);

c=a+b;

printf(“%d+%d=%d”,a,b,c);

}

就此結束此文吧,最後還得照例謙虛幾句,本人水平有限(的的確確有限^_^,這到是真話),謬誤難免還望達人指點一二,在下在此謝過了.

(全文完)

c語言中scanf是什麼意思,為什麼有時候後面寫%f,有時候寫%e,%lf,%c等等

scanf是C語言中的一個輸入函數,意思就是當你從鍵盤中輸入數值按回車後,他會把你輸入的數值儲存到電腦,至於為什麼後面會寫%f,%e.%lf,%c那是根據scanf的對象而定的。向float,double,char就分別用%f,%e,%c

scanf()函數是什麼意思?

scanf函數的作用是按照指定的格式從標準輸入流讀取數據。

標準輸入流就是指我們從鍵盤上輸入的按鍵。

比如我們一般輸入2個整數的話,那麼中間會使用空格進行間隔,這個就是scanf默認定義的格式。

C語言中的scanf是什麼意思

C語言中scanf是標準庫函數,主要用來接收用戶輸入的數據。

C標準函數庫是所有符合標準的頭文件的集合,以及常用的函數庫實現程序,例如I/O輸入輸出和字符串控制。不像這三種COBOL、Fortran和PL/I等編程語言,在C語言的工作任務里不會包含嵌入的關鍵字,所以幾乎所有的C語言程序都是由標準函數庫的函數來創建的。

C語言簡介

C語言是一門面向過程的計算機編程語言,與C++、C#、Java等面向對象編程語言有所不同。C語言的設計目標是提供一種能以簡易的方式編譯、處理低級存儲器、僅產生少量的機器碼以及不需要任何運行環境支持便能運行的編程語言。

C語言描述問題比彙編語言迅速、工作量小、可讀性好、易於調試、修改和移植,而代碼質量與彙編語言相當。C語言一般只比彙編語言代碼生成的目標程序效率低10%-20%。因此,C語言可以編寫系統軟件。

scanf在c語言中具體是什麼意思?

scanf是C語言的格式化輸入函數:

調用格式:scanf(輸入格式字符串,輸入變量地址表)

能夠從鍵盤上輸入各種基本類型的數據,並且可以控制輸入時數據的類型(即整型、實型、字符型、字符串)、數據的寬度(即輸入字符的個數)。

輸入-2,288↙

scanf(“%d,%d”,i1,i2);

可使變量i1的值為-2、i2的值為288

c語言里的scanf到底有什麼用?

c語言中scanf是標準庫函數,主要用來接收用戶輸入的數據。

函數格式:int

scanf(char

*format,

args,

…);

能:從標準輸入設備按format指定格式輸入數據給args所指向的內存單元

:讀入並賦給args的數據個數。遇文件結束返回eof,出錯返回0

舉例如下:

int a;

scanf(“%d”, a); // 按%d的格式(即整型的格式),將用戶輸入的數據賦值給a指向的內存單元(即變量a所在的內存單元)。

// 簡單理解就是將用戶輸入的數轉換為int類型並賦值給變量a

原創文章,作者:BQPR,如若轉載,請註明出處:https://www.506064.com/zh-hant/n/147212.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
BQPR的頭像BQPR
上一篇 2024-11-01 14:06
下一篇 2024-11-01 14:07

相關推薦

  • AES加密解密算法的C語言實現

    AES(Advanced Encryption Standard)是一種對稱加密算法,可用於對數據進行加密和解密。在本篇文章中,我們將介紹C語言中如何實現AES算法,並對實現過程進…

    編程 2025-04-29
  • Python3定義函數參數類型

    Python是一門動態類型語言,不需要在定義變量時顯示的指定變量類型,但是Python3中提供了函數參數類型的聲明功能,在函數定義時明確定義參數類型。在函數的形參後面加上冒號(:)…

    編程 2025-04-29
  • 學習Python對學習C語言有幫助嗎?

    Python和C語言是兩種非常受歡迎的編程語言,在程序開發中都扮演着非常重要的角色。那麼,學習Python對學習C語言有幫助嗎?答案是肯定的。在本文中,我們將從多個角度探討Pyth…

    編程 2025-04-29
  • Python定義函數判斷奇偶數

    本文將從多個方面詳細闡述Python定義函數判斷奇偶數的方法,並提供完整的代碼示例。 一、初步了解Python函數 在介紹Python如何定義函數判斷奇偶數之前,我們先來了解一下P…

    編程 2025-04-29
  • Python符號定義和使用方法

    本文將從多個方面介紹Python符號的定義和使用方法,涉及注釋、變量、運算符、條件語句和循環等多個方面。 一、注釋 1、單行注釋 # 這是一條單行注釋 2、多行注釋 “”” 這是一…

    編程 2025-04-29
  • Python被稱為膠水語言

    Python作為一種跨平台的解釋性高級語言,最大的特點是被稱為”膠水語言”。 一、簡單易學 Python的語法簡單易學,更加人性化,這使得它成為了初學者的入…

    編程 2025-04-29
  • Python中的隊列定義

    本篇文章旨在深入闡述Python中隊列的定義及其應用,包括隊列的定義、隊列的類型、隊列的操作以及隊列的應用。同時,我們也會為您提供Python代碼示例。 一、隊列的定義 隊列是一種…

    編程 2025-04-29
  • OpenJudge答案1.6的C語言實現

    本文將從多個方面詳細闡述OpenJudge答案1.6在C語言中的實現方法,幫助初學者更好地學習和理解。 一、需求概述 OpenJudge答案1.6的要求是,輸入兩個整數a和b,輸出…

    編程 2025-04-29
  • Python按位運算符和C語言

    本文將從多個方面詳細闡述Python按位運算符和C語言的相關內容,並給出相應的代碼示例。 一、概述 Python是一種動態的、面向對象的編程語言,其按位運算符是用於按位操作的運算符…

    編程 2025-04-29
  • Python編程技巧:如何定義一個函數n!,並計算5!

    在這篇文章中,我們將研究如何使用Python編程語言定義一個能夠計算階乘的函數,並且演示如何使用該函數計算5!。 一、階乘函數的定義 在Python中,我們可以使用一個簡單的遞歸函…

    編程 2025-04-29

發表回復

登錄後才能評論