本文轉載自http://www.cppblog.com/zenliang/archive/2010/11/07/132858.html
C中格式字符串printf()的一般形式爲: %[標誌][輸出最小寬度][.精度][長度]類型, 其中方括號[]中的項爲可選項。各項的意義介紹如下:
1.類型:
表示輸出類型的格式字符 |
格式字符意義 |
a | 浮點數、十六進制數字和p-計數法(C99) |
A | 浮點數、十六進制數字和p-計數法(C99) |
c | 輸出單個字符 |
d | 以十進制形式輸出帶符號整數(正數不輸出符號) |
e | 以指數形式輸出單、雙精度實數 |
E | 以指數形式輸出單、雙精度實數 |
f | 以小數形式輸出單、雙精度實數 |
g | 以%f%e中較短的輸出寬度輸出單、雙精度實數,%e格式在指數小於-4或者大 於等於精度時使用 |
G | 以%f%e中較短的輸出寬度輸出單、雙精度實數,%e格式在指數小於-4或者大於等於精度時使用 |
i | 有符號十進制整數(與%d相同) |
o | 以八進制形式輸出無符號整數(不輸出前綴O) |
p | 指針 |
s | 輸出字符串 |
x | 以十六進制(小寫)形式輸出無符號整數(不輸出前綴OX) |
X | 以十六進制(大寫)形式輸出無符號整數(不輸出前綴OX) |
u | 以十進制形式輸出無符號整數 |
2.標誌
標誌字符爲-、+、#、空格和0五種,其意義下表所示:
標誌格式字符 | 標 志 意 義 |
- | 結果左對齊,右邊填空格 |
+ | 輸出符號(正號或負號) |
空格 | 輸出值爲正時冠以空格,爲負時冠以負號 |
# | 對c,s,d,u類無影響;對o類,在輸出時加前綴0;對x類, 在輸出時加前綴0x或者0X;對g,G 類防止尾隨0被刪除;對於所有的浮點形式,#保證了即使不跟任何數字,也打印一個小數點字符。 |
0 | 對於所有的數字格式,用前導0填充字段寬度,若出現-標誌或者指定了精度(對於整數),忽略 |
3.輸出最小寬度
用十進制整數來表示輸出的最少位數。若實際位數多於定義的寬度,則按實際位數輸出,若實際位數少於定義的寬度則補以空格或0。
4.精度
精度格式符以“.”開頭,後跟十進制整數。本項的意義是:如果輸出數字,則表示小數的位數;如果輸出的是字符,則表示輸出字符的個數;若實際位數大於所定義的精度數,則截去超過的部分。
5.長度
長度格式符爲h,l兩種,h表示按短整型量輸出,l表示按長整型量輸出。
h和整數轉換說明符一起使用,表示一個short int 或者unsigned short int類型的數值 ,示例:
%hu,%hx,%6.4hd
hh和整數轉換說明符一起使用,表示一個short int 、unsigned short、unsigned char類型的數值 ,示例:
%hhu,%hhx,%6.4hhd
j和整數轉換說明符一起使用,表示一個intmax_t或者uintmax_t類型的數值 ,示例:
%jd,%8jx
l和整數轉換說明符一起使用,表示一個long int 或者unsigned long int類型的數值 ,示例:
%ld,%8lu
ll和整數轉換說明符一起使用,表示一個long int 或者unsigned long int類型的數值 (C99),示例:
%lld,%8llu
L和浮點轉換說明符一起使用,表示一個long double的值,示例:
%Lf,%10.4Le
t和整數轉換說明符一起使用,表示一個ptrdiff_t值(兩個指針之間的差相對應的類型)(C99),示例:
%td,%12ti
z和整數轉換說明符一起使用,表示一個size_t值(sizeof返回的類型)(C99),示例:
%zd,%12zx
使用printf函數時還要注意一個問題,那就是輸出表列中的求值順序。不同的編譯系統不一定相同,可以從左到右,也可從右到左。Turbo C是按從右到左進行的。