c語言中scanf的用法
c語言中scanf的用法
c語言中scanf的用法的用法你知道嗎?下面小編就跟你們詳細介紹下c語言中scanf的用法的用法,希望對你們有用。
c語言中scanf的用法的用法如下:
Printf和Scan函數(shù)的使用方法
一 printf()函數(shù)是格式化輸出函數(shù), 一般用于向標準輸出設(shè)備按規(guī)定格式輸出
信息。在編寫程序時經(jīng)常會用到此函數(shù)。printf()函數(shù)的調(diào)用格式為:
printf("<格式化字符串>", <參量表>);
其中格式化字符串包括兩部分內(nèi)容: 一部分是正常字符, 這些字符將按原
樣輸出; 另一部分是格式化規(guī)定字符, 以"%"開始, 后跟一個或幾個規(guī)定字符,
用來確定輸出內(nèi)容格式。
參量表是需要輸出的一系列參數(shù), 其個數(shù)必須與格式化字符串所說明的輸出
參數(shù)個數(shù)一樣多, 各參數(shù)之間用","分開, 且順序一一對應(yīng), 否則將會出現(xiàn)意想
不到的錯誤。
格式化字符串的格式是:
%[標志][輸出最小寬度][.精度][長度]格式字符
1. 標志:標志字符為-、+、#、空格四種,其意義下表所示:
標志 意義
- 結(jié)果左對齊,右邊填空格
+ 輸出符號(正號或負號)
空格 輸出值為正時冠以空格,為負時冠以負號
# 對c,s,d,u類無影響;對o類,在輸出時加前綴o;對x類,在輸出時加前綴0x;對e,g,f 類當結(jié)果有小數(shù) 時才給出小數(shù)點(??????)
例1:
?。 nclude
main()
{
int a=100;
float b=123.255;
printf("a=%d ",a);
printf("a=d ",a);
printf("a=%-10d ",a);
printf("a=%+d ",a);
printf("a=% d ",a);
printf("a=%#o ",a);
printf("a=%#x ",a);
printf("b=%#f ",b);
}
運行結(jié)果
a=100
a= 100
a=100
a=+100
a= 100
a=0144
a=0x64
b=123.254997 (?????)
2.輸出最小寬度:用十進制整數(shù)來表示輸出的最少位數(shù)。(至少要輸出這么多位?。?/p>
若實際位數(shù)多于定義的寬度:則按實際位數(shù)輸出。
若實際位數(shù)少于定義的寬度:則右對齊,左邊留空。
有負號,左對齊,右邊留空
表示寬度的數(shù)字以0開始,則右對齊,左邊留空。
例2 #i nclude
main()
{
int a=3456;
printf("a== ",a); //若實際位數(shù)多于定義的寬度:則按實際位數(shù)輸出
printf("a=d ",a); //若實際位數(shù)少于定義的寬度:則右對齊,左邊留空
printf("a=%-10d ",a); //若實際位數(shù)少于定義的寬度:有負號,左對齊,右邊留空
printf("a=0d ",a); //若實際位數(shù)少于定義的寬度:表示寬度的數(shù)字以0開始,則右對齊,左邊留空
printf("a=%-010d ",a); //左對齊,0無意義。
}
運行結(jié)果:
a=3456
a= 3456
a=3456
a=0000003456
a=3456
3.精度:精度格式符以“.”開頭,后跟十進制整數(shù)。意義是:
如果輸出數(shù)字,則表示小數(shù)的位數(shù);若實際位數(shù)大于所定義的精度數(shù),則四舍五入。若不足則補0;
如果輸出的是字符,則表示輸出字符的個數(shù);若實際位數(shù)大于所定義的精度數(shù),則截去超過的部分。
例3:
#i nclude
main()
{
printf("%.3f ",12.3456);
printf("%.9f ",12.3456);
printf("%.3s ","abcdefg");
printf("%.9s ","abcdefg");
}
運行結(jié)果:
12.346 //四舍五入到小數(shù)點后三位
12.345600000 //不足補0
abc
abcdefg
4.長度:長度格式符為h,l兩種,h表示按短整型量輸出,l表示按長整型量輸出?????
5.Turbo C2.0提供的格式字符如下:
━━━━━━━━━━━━━━━━━━━━━━━━━━
符號 作用
──────────────────────────
%c 單個字符
%d 十進制有符號整數(shù)
%e 以“科學(xué)記數(shù)法”的形式輸出十進制的浮點數(shù) 如2.451e+02
%f 輸出十進制浮點數(shù),不帶域?qū)挄r,保留6位小數(shù)
%g 選用e或f格式中較短的一個輸出十進制浮點數(shù),不輸出無效零
%0 無輸出無符號八進制整數(shù)
%p 指針的值
%s 輸出字符串
%u 輸出無符號十進制整數(shù)
%x, %X 輸出無符號十六進制整數(shù) (不輸出前綴Ox)
━━━━━━━━━━━━━━━━━━━━━━━━━━
2. 一些特殊規(guī)定字符
━━━━━━━━━━━━━━━━━━━━━━━━━━
字符 作用
──────────────────────────
換行
f 清屏并換頁
回車
Tab符
xhh 表示一個ASCII碼用16進表示,
其中hh是1到2個16進制數(shù)
━━━━━━━━━━━━━━━━━━━━━━━━━━
使用這些轉(zhuǎn)義字符時不需要加上%,可單獨使用!
由本節(jié)所學(xué)的printf()函數(shù), 并結(jié)合上一節(jié)學(xué)習的數(shù)據(jù)類型, 編制下面的程
序, 以加深對Turbo C2.0數(shù)據(jù)類型的了解。
例1
?。 nclude
?。 nclude
int main()
{
char c, s[20], *p;
int a=1234, *i;
float f=3.141592653589;
double x=0.12345678987654321;
p="How do you do";
strcpy(s, "Hello, Comrade");
*i=12;
c='x41';
printf("a=%d ", a);
printf("a=m ", a);
printf("a=d ", a);
printf("a=- ", a);
printf("*i=M ", *i);
printf("*i=%-4d ", *i);
printf("i=%p ", i);
printf("f=%f ", f);
printf("f=6.4f ", f);
printf("x=%lf ", x);
printf("x=.16lf ", x);
printf("c=%c ", c);
printf("c=%x ", c);
printf("s[]=%s ", s);
printf("s[]=%6.9s ", s);
printf("s=%p ", s);
printf("*p=%s ", p);
printf("p=%p ", p);
getch();
retunr 0;
}
其他需要注意的一些問題:
1.如果用浮點數(shù)表示字符或整型量的輸出格式, 小數(shù)點后的數(shù)字代表最大寬度,
小數(shù)點前的數(shù)字代表最小寬度。
例如: %6.9s 表示顯示一個長度不小于6且不大于9的字符串。若大于9, 則第9個字符以后的內(nèi)容將被刪除。
2.使用printf函數(shù)時還要注意一個問題,那就是輸出表列中的求值順序。不同的編譯系統(tǒng)不一定相同,可以從左到右,也可從右到左。Turbo C是按從右到左進行的。請看下面兩個例子:
例1
main(){
int i=8;
printf("%d %d %d %d %d %d ",++i,--i,i++,i--,-i++,-i--);
}
運行結(jié)果
8
7
7
8
-7
-8
例2
main(){
int i=8;
printf("%d ",++i);
printf("%d ",--i);
printf("%d ",i++);
printf("%d ",i--);
printf("%d ",-i++);
printf("%d ",-i--);
}
運行結(jié)果:
9
8
8
9
-8
-9
這兩個程序的區(qū)別是用一個printf語句和多個printf 語句輸出。但從結(jié)果可以看出是不同的。為什么結(jié)果會不同呢?就是因為printf函數(shù)對輸出表中各量求值的順序是自右至左進行的。在第一例中,先對最后一項“-i--”求值,結(jié)果為-8,然后i自減1后為7。 再對“-i++”項求值得-7,然后i自增1后為8。再對“i--”項求值得8,然后i再自減1后為7。再求“i++”項得7,然后i再自增1后為8。 再求“--i”項,i先自減1后輸出,輸出值為7。 最后才求輸出表列中的第一項“++i”,此時i自增1后輸出8。
但是必須注意,求值順序雖是自右至左,但是輸出順序還是從左至右,因此得到的結(jié)果是上述輸出結(jié)果。
補充:最近在調(diào)試程序時發(fā)現(xiàn)一段代碼如下:
printf(sFormat,"%%0?",THE_NUMBER_LEN);
輸出數(shù)組后發(fā)現(xiàn)sFormat = d;其中宏THE_NUMBER_LEN定義的為4,發(fā)現(xiàn)如果需要通過在printf轉(zhuǎn)化的數(shù)組中出現(xiàn)%,那么就使用%%來代替,且后面的所有字符都會直接放入sFormat數(shù)組中一直遇到新的%。只有碰到“%+特定字符”,才會把右邊對應(yīng)的變量放入進來。
例如: printf(sFormat,"ABC%%d%d%%s?bc",THE_NUMBER_LEN,6);輸出為ABC?%s6abc;
還有就是發(fā)現(xiàn)如果是修改成%0?,輸出的字符串就變成 ?,這樣我猜想就是在printf函數(shù)時,碰到第一個%0后知道再遇見下一個%前,如果中間沒有特定字符d,s,e,f等,通通變成空格,而我在%中間增加兩個的非特殊字符后,發(fā)現(xiàn)?前面的空格急劇增加,原因就不清楚。故兩%之間不能增加其他非特殊字符。
二 Scan函數(shù)
數(shù)
scanf()函數(shù)是格式化輸入函數(shù), 它從標準輸入設(shè)備(鍵盤) 讀取輸入的信息。
其調(diào)用格式為:
scanf("<格式化字符串>", <地址表>);
格式化字符串包括以下三類不同的字符;
1. 格式化說明符: 格式化說明符與printf()函數(shù)中的格式說明符基本相同。
2. 空白字符: 空白字符會使scanf()函數(shù)在讀操作中略去輸入中的一個或多
個空白字符。
3. 非空白字符: 一個非空白字符會使scanf()函數(shù)在讀入時剔除掉與這個非
空白字符相同的字符。
注意:(1)地址表是需要讀入的所有變量的地址, 而不是變量本身:
----如果是一般的變量,通常要在變量名前加上"&";但輸出時是用變量名
----如果是數(shù)組,用數(shù)組名就代表了該數(shù)組的首地址;輸出時也是用數(shù)組名
----如果是指針,直接用指針名本身,不要加上“*”;輸出時也用該指針即可。
例1:
各個變量的地址之間同","分開。
main()
{
int i;
char *p, str[20];
scanf("%d", &i);
scanf("%s", p);
scanf("%s", str);
printf("i=%d ",i);
printf("%s ", p);
printf("%s ", str);
}
?。?)scanf函數(shù)中是否包含空白/非空白字符導(dǎo)致輸入格式的不同
如:scanf("%d,%d",&i,&j); scanf中有,所以輸入的格式應(yīng)該是5,6==>i=5,j=6
scanf("%d%d",&i,&j); 可以用空格或回車來分隔兩個輸入 如 5 6==>i=5,j=6
scanf("%d %d",&i,&j); 同上
(3) 實際使用scanf()函數(shù)時存在一個問題, 下面舉例進行說明:
當使用多個scanf()函數(shù)連續(xù)給多個字符變量輸入時, 例如:
main()
{
char c1, c2;
scanf("%c", &c1);
scanf("%c", &c2);
printf("c1 is %c, c2 is %c", c21, c2);
}
運行該程序, 輸入一個字符A后回車 (要完成輸入必須回車), 在執(zhí)行scanf
("%c", &c1)時, 給變量c1賦值"A", 但回車符仍然留在緩沖區(qū)內(nèi), 執(zhí)行輸入語句
scanf("%c", &c2)時, 變量c2輸出的是一空行, 如果輸入AB后回車, 那么輸出結(jié)
果為: c1 is A, c2 is B。
要解決以上問題, 可以在輸入函數(shù)前加入清除函數(shù)fflush()( 這個函數(shù)的使
用方法將在本節(jié)最后講述)。修改以上程序變成:
?。 nclude
main()
{
char c1, c2;
scanf("%c", &c1);
fflush(stdin);
scanf("%c", &c2);
printf("c1 is %c, c2 is %c", c1, c2);
}
在輸入字符數(shù)據(jù)時,若格式控制串中無非格式字符,則認為所有輸入的字符均為有效字符。
例如:scanf("%c%c%c",&a,&b,&c);
輸入為:d e f
則把'd'賦予a, ' ' 賦予b,'e'賦予c。
只有當輸入為: def
時,才能把'd'賦于a,'e'賦予b,'f'賦予c。
如果在格式控制中加入空格作為間隔,
如:scanf ("%c %c %c",&a,&b,&c);
則輸入時各數(shù)據(jù)之間可加空格。
例4
main(){
char a,b;
printf("input character a,b ");
scanf("%c%c",&a,&b);
printf("%c%c ",a,b);
}
由于scanf函數(shù)"%c%c"中沒有空格,輸入M N,結(jié)果輸出只有M。而輸入改為MN時則可輸出MN兩字符。
(4)格式字符串的一般形式為:
%
[輸入數(shù)據(jù)寬度][長度]類型
其中有方括號[]的項為任選項。各項的意義如下:
1)類型:表示輸入數(shù)據(jù)的類型,其格式符和意義如下表所示。
格式 字符意義
d 輸入十進制整數(shù)
o 輸入八進制整數(shù)
x 輸入十六進制整數(shù)
u 輸入無符號十進制整數(shù)
f或e 輸入實型數(shù)(用小數(shù)形式或指數(shù)形式)
c 輸入單個字符
s 輸入字符串
2)“*”符:用以表示該輸入項,讀入后不賦予相應(yīng)的變量,即跳過該輸入值。
如:scanf("%d %*d %d",&a,&b);
當輸入為:1 2 3時,把1賦予a,2被跳過,3賦予b。
3)寬度:用十進制整數(shù)指定輸入的寬度(即字符數(shù))。
例如:
scanf("]",&a);
輸入:12345678
只把12345賦予變量a,其余部分被截去。
又如:scanf("MM",&a,&b);
輸入:12345678
將把1234賦予a,而把5678賦予b。
例:
main()
{
int a,b;
scanf("MM",&a,&b);
printf("a=%d,b=%d",a,b);
}
輸入 12345 67890
運行結(jié)果 a=1234,b=5
4) 長度:長度格式符為l和h,l表示輸入長整型數(shù)據(jù)(如%ld) 和雙精度浮點數(shù)(如%lf)。h表示輸入短整型數(shù)據(jù)。
使用scanf函數(shù)還必須注意以下幾點:
1)scanf函數(shù)中沒有精度控制,如:scanf("%5.2f",&a);是非法的。不能企圖用此語句輸入小數(shù)為2位的實數(shù)。
2)在輸入多個數(shù)值數(shù)據(jù)時,若格式控制串中沒有非格式字符作輸入數(shù)據(jù)之間的間隔則可用空格,TAB或回車作間隔。C編譯在碰到空格,TAB,回車或非法數(shù)據(jù)(如對“%d”輸入“12A”時,A即為非法數(shù)據(jù))時即認為該數(shù)據(jù)結(jié)束。