c printf格式總結
轉自:點選開啟連結
1.呼叫格式為 printf("<格式化字串>", <參量表>);
其中格式化字串包括兩部分內容: 一部分是正常字元, 這些字元將按原樣輸出; 另一部分是格式化規定字元, 以"%"開始, 後跟一個或幾個規定字元, 用來確定輸出內容格式。參量表是需要輸出的一系列引數,其個數必須與格式化字串所說明的輸出引數個數一樣多, 各引數之間用","分開, 且順序一一對應, 否則將會出現意想不到的錯誤。
2.格式化字元
%d 十進位制有符號整數
%u 十進位制無符號整數
%f 浮點數
%s 字串
%c 單個字元
%p 指標的值
%e 指數形式的浮點數
%x, %X 無符號以十六進位制表示的整數
%0 無符號以八進位制表示的整數
%g 自動選擇合適的表示法
說明:
(1). 可以在"%"和字母之間插進數字表示最大場寬。 例如: %3d 表示輸出3位整型數
(2). 可以在"%"和字母之間加小寫字母l, 表示輸出的是長型數。例如: %ld 表示輸出long整數, %lf 表示輸出double浮點數。
(3). 可以控制輸出左對齊或右對齊, 即在"%"和字母之間加入一個"-" 號可說明輸出為左對齊, 否則為右對齊。例如: %-7d 表示輸出7位整數左對齊,%-10s 表示輸出10個字元左對齊。
3. 一些特殊規定字元
\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個字元以後的內容將被刪除。