C語言printf詳解


本文轉載自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是按從右到左進行的。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章