printf格式化輸出函數詳解,并附帶最新典型案例
時間:2018-06-14 來源:未知
printf函數是一個標準庫函數,它的函數原型在頭文件“stdio.h”中。但作為一個特例,不要求在使用 printf 函數之前必須包含stdio.h文件。printf函數調用的一般形式為:
printf(“格式控制字符串”, 輸出表列)
其中格式控制字符串用于指定輸出格式。格式控制串可由格式字符串和非格式字符串兩種組成。格式字符串是以%開頭的字符串,在%后面跟有各種格式字符,以說明輸出數據的類型、形式、長度、小數位數等。如:
“%d”表示按十進制整型輸出;
“%ld”表示按十進制長整型輸出;
“%c”表示按字符型輸出等。
非格式字符串原樣輸出,在顯示中起提示作用。輸出表列中給出了各個輸出項,要求格式字符串和各輸出項在數量和類型上應該一一對應。
【例4-3】printf函數舉例
#include
int main(void){
int a=88,b=89;
printf("%d %d\n",a,b);
printf("%d,%d\n",a,b);
printf("%c,%c\n",a,b);
printf("a=%d,b=%d",a,b);
return 0;
}
本例中四次輸出了a、b的值,但由于格式控制串不同,輸出的結果也不相同。第3行的輸出語句格式控制串中,兩格式串%d 之間加了一個空格(非格式字符),所以輸出的a、b值之間有一個空格。第4行的printf語句格式控制串中加入的是非格式字符逗號,因此輸出的a、b值之間加了一個逗號。第5行的格式串要求按字符型輸出a、b值。第6行中為了提示輸出結果又增加了非格式字符串。
格式字符串
在Turbo C中格式字符串的一般形式為:
[標志][輸出最小寬度][.精度][長度]類型。
其中方括號[]中的項為可選項。
各項的意義介紹如下。
1) 類型
類型字符用以表示輸出數據的類型,其格式符和意義如下表所示:
格式字符意義
d以十進制形式輸出帶符號整數(正數不輸出符號)
o以八進制形式輸出無符號整數(不輸出前綴0)
x,X以十六進制形式輸出無符號整數(不輸出前綴Ox)
u以十進制形式輸出無符號整數
f以小數形式輸出單、雙精度實數
e,E以指數形式輸出單、雙精度實數
g,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表示按長整型量輸出。
【例4-4】
#include
int main(void){
int a=15;
long float b=123.1234567;
// 原來b的定義為 float b=123.1234567;
double c=12345678.1234567;
char d='p';
printf("a=%d\n", a);
printf("a(%%d)=%d, a(%%5d)=%5d, a(%%o)=%o, a(%%x)=%x\n\n",a,a,a,a); // %% 可以輸出 %
printf("a=%f\n", b);
printf("b(%%f)=%f, b(%%lf)=%lf, b(%%5.4lf)=%5.4lf, b(%%e)=%e\n\n",b,b,b,b);
printf("c=%f\n", c);
printf("c(%%lf)=%lf, c(%%f)=%f, c(%%8.4lf)=%8.4lf\n\n",c,c,c);
printf("d=%c\n", d);
printf("d(%%c)=%c, d(%%8c)=%8c\n",d,d);
return 0;
}
運行結果:
本例中:
第11行以四種格式輸出整型變量a的值,其中“%5d ”要求輸出寬度為5,而a值為15只有兩位故補三個空格。
第14行以四種格式輸出實型量b的值。其中“%f”和“%lf ”格式的輸出相同,說明“l”符對“f”類型無影響。“%5.4lf”指定輸出寬度為5,精度為4,由于實際長度超過5故應該按實際位數輸出,小數位數超過4位部分被截去。
第17行輸出雙精度實數,“%8.4lf ”由于指定精度為4位故截去了超過4位的部分。
第20行輸出字符量d,其中“%8c ”指定輸出寬度為8故在輸出字符p之前補加7個空格。
使用printf函數時還要注意一個問題,那就是輸出表列中的求值順序。不同的編譯系統不一定相同,可以從左到右,也可從右到左。Turbo C是按從右到左進行的。請看下面兩個例子。
【例4-5】在一個printf()里輸出
#include
int main(void){
int i=8;
printf("The raw value: i=%d\n", i);
printf("++i=%d \n++i=%d \n--i=%d \n--i=%d\n",++i,++i,--i,--i);
return 0;
}
運行結果:
The raw value: i=8
++i=8
++i=7
--i=6
--i=7
【例4-6】在多個printf()里輸出
#include
int main(void){
int i=8;
printf("The raw value: i=%d\n", i);
printf("++i=%d\n", ++i);
printf("++i=%d\n", ++i);
printf("--i=%d\n", --i);
printf("--i=%d\n", --i);
return 0;
}
運行結果:

The raw value: i=8
++i=9
++i=10
--i=9
--i=8
這兩個程序的區別是用一個printf語句和多個printf 語句輸出。但從結果可以看出是不同的。為什么結果會不同呢?就是因為printf函數對輸出表中各量求值的順序是自右至左進行的。
但是必須注意,求值順序雖是自右至左,但是輸出順序還是從左至右,因此得到的結果是上述輸出結果。
下面是老代碼及分析:
【例4-5】
main(){
int i=8;
printf("%d\n%d\n%d\n%d\n%d\n%d\n",++i,--i,i++,i--,-i++,-i--);
}
【例4-6】
main(){
int i=8;
printf("%d\n",++i);
printf("%d\n",--i);
printf("%d\n",i++);
printf("%d\n",i--);
printf("%d\n",-i++);
printf("%d\n",-i--);
}
這兩個程序的區別是用一個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。

