其中格式化字串包括兩部分內容: 一部分是正常字元, 這些字元將按原樣輸出; 另一部分是格式化規定字元, 以"%"開始, 後跟乙個或幾個規定字元, 用來確定輸出內容格式。參量表是需要輸出的一系列引數, 其個數必須與格式化字串所說明的輸出引數個數一樣多, 各引數之間用","分開, 且順序一一對應, 否則將會出現意想不到的錯誤。
%d 十進位制有符號整數
%u 十進位制無符號整數
%f 浮點數
%s 字串
%c 單個字元
%p 指標的值
%e 指數形式的浮點數
%x, %x 無符號以十六進製制表示的整數
%0 無符號以八進位制表示的整數
%g 自動選擇合適的表示法
(1). 可以在"%"和字母之間插進數字表示最大場寬。 例如: %3d 表示輸出3位整型數, 不夠3位右對齊。%9.2f 表示輸出場寬為9的浮點數, 其中小數字為2, 整數字為6, 小數點佔一位, 不夠9位右對齊。超過9位,按實際輸出。%8s 表示輸出8個字元的字串, 不夠8個字元右對齊。 如果字串的長度、或整型數字數超過說明的場寬, 將按其實際長度輸出。 但對浮點數, 若整數部分位數超過了說明的整數字寬度, 將按實際整數字輸出; 若小數部分位數超過了說明的小數字寬度, 則按說明的寬度以四捨五入輸出。另外, 若想在輸出值前加一些0, 就應在場寬項前加個0。 例如: %04d 表示在輸出乙個小於4位的數值時, 將在前面補0使其總寬度為4位。如果用浮點數表示字元或整型量的輸出格式, 小數點後的數字代表最大寬度, 小數點前的數字代表最小寬度。 例如: %6.9s 表示顯示乙個長度不小於6且不大於9的字串。若大於9, 則第9個字元以後的內容將被刪除。
(2). 可以在"%"和字母之間加小寫字母l, 表示輸出的是長型數。例如: %ld 表示輸出long整數, %lf 表示輸出double浮點數。
(3). 可以控制輸出左對齊或右對齊, 即在"%"和字母之間加入乙個"-" 號可說明輸出為左對齊, 否則為右對齊。例如: %-7d 表示輸出7位整數左對齊,%-10s 表示輸出10個字元左對齊。
\n換行
\f清屏並換頁
\r回車
\t tab符
\xhh表示乙個ascii碼用16進表示,
其中hh是1到2個16進製制數
int a=1234;
printf("a=%d\n",a); //a=1234
printf("a=%2d\n",a); //a=1234 超過2位,按實際輸出
printf("a=%6d\n",a); //a= 1234 不足6位,右對齊
printf("a=%06d\n",a); //a=001234 不足6位,前面補0
printf("a=%-6d\n",a); //a=1234 '-'左對齊
int* i=&a;
printf("i=%p\n",i); //i=0012ff44 輸出指標的值,即位址
float m=8888.8888; //float 單精度型浮點數 有效位數是6位或7位,根據不同的浮點數會有不同
float m1=8888.8888f; //在後面加上f或f,編譯警告:truncation from'const double'to 'float'
//編譯器預設浮點數為double
float m2=8888.888f;
double n=8888.8888;
double n1=8888888888.88888888; //double 雙精度型浮點數 有效位數是15位
printf("m=%f\n m1=%f\n m2=%f\n n=%lf\n n1=%f\n",m,m1,m2,n,n1); // m=8888.888672
// m1=8888.888672
// m2=8888.887695
// n=8888.888800
// n1=8888888888.888889
//%f的預設輸出小數字數就是6位不管有沒有l
/*printf的%f說明符的確既可以輸出float型又可以輸出 double型。 根據"預設引數提公升"規則(在printf這樣的函式的
可變引數列表中 ,不論作用域內有沒有原型,都適用這一規則)float型會被提公升為double型。因此printf()只會看到
雙精度數。嚴格地講,%lf在printf下是未定義的,但是很多系統可能會接受它。要確保可移植性,就要堅持使用%f。*/
printf("m4=%4.2f\n",m); //寬度總共4位,小數兩位,小數點一位,整數一位,這裡整數超過寬度規定,按實際整數字輸出
printf("m5=%9.6f\n",m); //浮點數小數部分不足6位,右對齊
printf("m6=%9.2f\n",m); //整數部分不足6位,右對齊;小數部分超過2位,四捨五入
char c[20]="hello,world!";
printf("c=%s\n",c);
printf("c=%6.9s\n",c); //c=hello,wor 6.9s表示輸出乙個長度長度不小於6且不大於9的字串。若大於9, 則第9個字元以後的內容將被刪除。
C語言格式化輸出
1.格式控制符形式 o 格式控制符 其中,中括號裡的內容是可選的,裡的內容是必須的。以下對各個標誌的含義簡要介紹 表示格式控制的起始符號,必不可少。格式控制起始位置 表示對齊標誌,表示右對齊,表示左對其,預設情況下為右對齊。對齊標誌 o 表示當實際長度沒有格式控制的長度大時,用 o 補全。補全內容 ...
C語言格式化輸出
d整型輸出,d長整型輸出 o以八進位制數形式輸出整數 x以十六進製制數形式輸出整數,或輸出字串的位址 u以十進位制數輸出unsigned型資料 無符號數 c用來輸出乙個字元 挨個輸出陣列中的元素 s用來輸出乙個字串 一次輸出整個陣列的元素 f用來輸出實數,以小數形式輸出,預設情況下保留小數點6位 e...
c語言中格式化
符號 作用 d 十進位制有符號整數 u 十進位制無符號整數 f 浮點數 s 字串 c 單個字元 p 指標的值 e 指數形式的浮點數 x,x 無符號以十六進製制表示的整數 0 無符號以八進位制表示的整數 g 自動選擇合適的表示法 說明 1 可以在 和字母之間插進數字表示最大場寬。例如 3d 表示輸出3...