1樓:【血戮】龍桄
printf函式呼叫的一般形式 printf函式是乙個標準庫函式,它的函
數原型在標頭檔案「stdio.h」中。但作為乙個特例,不要求在使用 printf 函式之前必須包含stdio.
h檔案。printf函式呼叫的一般形式為: printf(「格式控制字串」,輸出表列)其中格式控制字串用於指定輸出格式。
格式控制串可由格式字串和非格式字串兩種組成。格式字串是以%開頭的字串,在%後面跟有各種格式字元,以說明輸出資料的型別、形式、長度、小數字數等。如「%d」表示按十進位制整型輸出,「%ld」表示按十進位製長整型輸出,「%c」表示按字元型輸出等。
後面將專門給予討論。 非格式字串在輸出時原樣照印,在顯示中起提示作用。 輸出表列中給出了各個輸出項, 要求格式字串和各輸出項在數量和型別上應該一一對應。
void main() a<--8,b<本例中四次輸出了a,b的值,但由於格式控制串不同,輸出的結果也不相同。第四行的輸出語句格式控制串中,兩格式串%d 之間加了乙個空格(非格式字元),所以輸出的a,b值之間有乙個空格。第五行的printf語句格式控制串中加入的是非格式字元逗號, 因此輸出的a,b值之間加了乙個逗號。
第六行的格式串要求按字元型輸出 a,b值。第七行中為了提示輸出結果又增加了非格式字串。
二、格式字串 在turbo c中格式字串的一般形式為: [標誌][輸出最小寬度][.精度][長度]型別 其中方括號中的項為可選項。
各項的意義介紹如下: 1.型別型別字元用以表示輸出資料的型別,其格式符和意義下表所示:
表示輸出型別的格式字元 格式字元意義 d 以十進位制形式輸出帶符號整數(正數不輸出符號) o 以八進位制形式輸出無符號整數(不輸出字首o) x 以十六進製制形式輸出無符號整數(不輸出字首ox) u 以十進位制形式輸出無符號整數 f 以小數形式輸出單、雙精度實數 e 以指數形式輸出單、雙精度實數 g 以%f%e中較短的輸出寬度輸出單、雙精度實數 c 輸出單個字元 s 輸出字串 2.標誌 標誌字元為-、+、#、空格四種,其意義下表所示: 標誌格式字元 標誌意義 - 結果左對齊,右邊填空格 + 輸出符號(正號或負號)空格輸出值為正時冠以空格,為負時冠以負號 # 對c,s,d,u類無影響;對o類, 在輸出時加前 綴o 對x類,在輸出時加字首0x;對e,g,f 類當結果有小數時才給出小數點 3.
輸出最小寬度 用十進位制整數來表示輸出的最少位數。 若實際位數多於定義的寬度,則按實際位數輸出, 若實際位數少於定義的寬度則補以空格或0。 4.
精度 精度格式符以「.」開頭,後跟十進位制整數。本項的意義是:
如果輸出數字,則表示小數的位數;如果輸出的是字元, 則表示輸出字元的個數;若實際位數大於所定義的精度數,則截去超過的部分。 5.長度 長度格式符為h,l兩種,h表示按短整型量輸出,l表示按長整型量輸出。
void main() a<--15 b<--138.3576278 c<--35648256.3645687 d<--'p' main() 本例第七行中以四種格式輸出整型變數a的值,其中「%5d 」要求輸出寬度為5,而a值為15只有兩位故補三個空格。
第八行中以四種格式輸出實型量b的值。其中「%f」和「%lf 」格式的輸出相同,說明「l」符對「f」型別無影響。「%5.
4lf」指定輸出寬度為5,精度為4,由於實際長度超過5故應該按實際位數輸出,小數字數超過4位部分被截去。第九行輸出雙精度實數,「%8.4lf 」由於指定精度為4位故截去了超過4位的部分。
第十行輸出字元量d,其中「%bc 」指定輸出寬度為8故在輸出字元p之前補加7個空格。 使用printf函式時還要注意乙個問題, 那就是輸出表列中的求值順序。不同的編譯系統不一定相同,可以從左到右, 也可從右到左。
turbo c是按從右到左進行的。如把例2.13改寫如下述形式:
void main() i<--8 這個程式與例2.13相比只是把多個printf語句改乙個printf 語句輸出。但從結果可以看出是不同的。
為什麼結果會不同呢?就是因為printf函式對輸出表中各量求值的順序是自右至左進行 的。在式中,先對最後一項「-i--」求值,結果為-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。但是必須注意, 求值順序雖是自右至左,但是輸出順序還是從左至右, 因此得到的結果是上述輸出結果。
字元輸出函式 putchar 函式 putchar 函式是字元輸出函式, 其功能是在顯示器上輸出單個字元。其一般形式為: putchar(字元變數) 例如:
putchar('a'); 輸出大寫字母a putchar(x); 輸出字元變數x的值 putchar('\n'); 換行 對控制字元則執行控制功能,不在螢幕上顯示。 使用本函式前必須要用檔案包含命令: #includevoid main() 資料輸入語句 c語言的資料輸入也是由函式語句完成的。
本節介紹從標準輸入裝置—鍵盤上輸入資料的函式scanf和getchar。 scanf函式 scanf函式稱為格式輸入函式,即按使用者指定的格式從鍵盤上把資料輸入到指定的變數之中。
一、scanf函式的一般形式 scanf函式是乙個標準庫函式,它的函式原型在標頭檔案「stdio.h」中,與printf函式相同,c語言也允許在使用scanf函式之前不必包含stdio.h檔案。
scanf函式的一般形式為: scanf(「格式控制字串」,位址表列); 其中,格式控制字串的作用與printf函式相同,但不能顯示非格式字串, 也就是不能顯示提示字串。位址表列中給出各變數的位址。
位址是由位址運算子「&」後跟變數名組成的。例如,&a,&b分別表示變數a和變數b 的位址。這個位址就是編譯系統在記憶體中給a,b變數分配的位址。
在c語言中,使用了位址這個概念,這是與其它語言不同的。 應該把變數的值和變數的位址這兩個不同的概念區別開來。變數的位址是c編譯系統分配的,使用者不必關心具體的位址是多少。
變數的位址和變數值的關係如下: &a--->a567 a為變數名,567是變數的值,&a是變數a的位址。在賦值表示式中給變數賦值,如:
a=567 在賦值號左邊是變數名,不能寫位址,而scanf函式在本質上也是給變數賦值,但要求寫變數的位址,如&a。 這兩者在形式上是不同的。&是乙個取位址運算子,&a是乙個表示式,其功能是求變數的位址。
void main() 注意&的用法! 在本例中,由於scanf函式本身不能顯示提示串,故先用printf語句在螢幕上輸出提示,請使用者輸入a、b、c的值。執行scanf語句,則退出tc螢幕進入使用者螢幕等待使用者輸入。
使用者輸入7、8、9後按下回車鍵,此時,系統又將返回tc螢幕。在scanf語句的格式串中由於沒有非格式字元在「%d%d%d」之間作輸入時的間隔, 因此在輸入時要用乙個以上的空格或回車鍵作為每兩個輸入數之間的間隔。 如:
7 8 9 或 7 8 9 格式字串 格式字串的一般形式為: %[*][輸入資料寬度][長度]型別 其中有方括號的項為任選項。各項的意義如下:
1.型別 表示輸入資料的型別,其格式符和意義下表所示。 格式 字元意義 d 輸入十進位制整數 o 輸入八進位制整數 x 輸入十六進製制整數 u 輸入無符號十進位制整數 f或e 輸入實型數(用小數形式或指數形式) c 輸入單個字元 s 輸入字串 2.
「*」符 用以表示該輸入項讀入後不賦予相應的變數,即跳過該輸入值。 如 scanf("%d %*d %d",&a,&b);當輸入為:1 2 3 時,把1賦予a,2被跳過,3賦予b。
3.寬度 用十進位制整數指定輸入的寬度(即字元數)。例如:
scanf("%5d",&a); 輸入: 12345678 只把12345賦予變數a,其餘部分被截去。又如:
scanf("%4d%4d",&a,&b); 輸入: 12345678將把1234賦予a,而把5678賦予b。 4.
長度 長度格式符為l和h,l表示輸入長整型資料(如%ld) 和雙精度浮點數(如%lf)。h表示輸入短整型資料。 使用scanf函式還必須注意以下幾點:
a. scanf函式中沒有精度控制,如: scanf("%5.
2f",&a); 是非法的。不能企圖用此語句輸入小數為2位的實數。 b.
scanf中要求給出變數位址,如給出變數名則會出錯。如 scanf("%d",a);是非法的,應改為s**af("%d",&a);才是合法的。 c.
在輸入多個數值資料時,若格式控制串中沒有非格式字元作輸入資料之間的間隔則可用空格,tab或回車作間隔。c編譯在碰到空格,tab,回車或非法資料(如對「%d」輸入「12a」時,a即為非法資料)時即認為該資料結束。 d.
在輸入字元資料時,若格式控制串中無非格式字元,則認為所有輸入的字元均為有效字元。例如: scanf("%c%c%c",&a,&b,&c); 輸入為:
d e f 則把'd'賦予a, 'f'賦予b,'e'賦予c。只有當輸入為: def 時,才能把'd'賦於a,'e'賦予b,'f'賦予c。
如果在格式控制中加入空格作為間隔,如 scanf ("%c %c %c",&a,&b,&c);則輸入時各資料之間可加空格由於scanf函式"%c%c"中沒有空格,輸入m n,結果輸出只有m。 而輸入改為mn時則可輸出mn兩字元,見下面的輸入運**況:
本例表示scanf格式控制串"%c %c"之間有空格時, 輸入的資料之間可以有空格間隔。e. 如果格式控制串中有非格式字元則輸入時也要輸入該非格式字元。
例如其中用非格式符「 , 」作間隔符,故輸入時應為: 5,6,7 又如:
則輸入應為 a=5,b=6,c=7g. 如輸入的資料與輸出的型別不一致時,雖然編譯能夠通過,但結果將不正確。 void main() 由於輸入資料型別為整型, 而輸出語句的格式串中說明為長整型,因此輸出結果和輸入資料不符。
如改動程式如下: void main() 執行結果為: input a long integer 1234567890 1234567890 當輸入資料改為長整型後,輸入輸出資料相等。
在c語言中 是什麼意思,C語言中 c是什麼意思
1 c語言中 是兩個運算子擺放在一起,是賦值運算子,邏輯非運算子 2 邏輯操作符一般將其運算元視為條件表示式,返回結果為bool型別 3 首先對其運算元求值,若結果為0,則條件為假 false 否則為真 true 4 優先順序上 先於 所有比如有下面的式子,int i i 5 5 這個理解為 根據運...
c語言中是什麼意思,C語言中 是什麼意思?
你好,a b表示a a b a b表示a a b 是c語言的運算子部分的知識 其中 是結構體指標的知識 條件運算子 a?b c表示a為真則執行b,否則執行c 運算子的知識,叫自反賦值運算子 a b相當於a a b a b相當於a b 是指向成員運算子 不懂可以問我 c語言中輸出語句中用到 c,表示輸...
c語言中o是什麼意思,C語言中 c是什麼意思
o意思是以八進位制整bai型式輸出整du數。c語言zhi中對於不同型別的資料用dao不同的格式字元內。x格式符,以十六進製制數容形式輸出整數。u格式符,用來輸出unsigned型資料,即無符號數,以十進位制形式輸出。c格式符,用來輸出乙個字元。s格式符,用來輸出乙個字串。擴充套件資料 scanfse...