printf 對應的字符代表的意思如下所示:
printf("%_", i); /* %a:浮點數、十六進制數字和p-記數法(C99) * %A:浮點數、十六進制數字和p-記法(C99) * %c:一個字符char * %C:一個ISO寬字符 * %d:有符號十進制整數int * %ld,%Ld:長整型數據long * %hd:短整型數據 * %e:浮點數、e-記數法 * %E:浮點數、E-記數法 * %f:單精度浮點數(默認float),十進制記數法 * %.nf:這里n表示精確到小數位后n位,十進制記數法 * %g:根據數值不同自動選擇%f或%e * %G:根據數值不同自動選擇%f或%e * %i:有符號十進制數(與%d相同) * %o:無符號八進制整數 * %p:指針 * %s:對應字符串char*(%s == %hs == %hS輸出窄字符串) * %S:對應寬字符串WCAHR*(%ws == %S輸出寬字符串) * %u:無符號十進制整數unsigned int * %x:無符號十六進制整數(形式為2f) * %#x:無符號十六進制整數(形式為0x2f) * %X:無符號十六進制整數(形式為2F) * %#X:無符號十六進制整數(形式為0x2F) * %%:打印一個百分號 * %lld:用於INT64或者long long * %llu:用於UINT64或者unsigned long long * %llx:用於64位16進制數據
*/
printf 控制符說明
printf("%ld", i);
/* %:表示格式說明的起始符號,不可缺少
* -:有-表示左對齊輸出,如省略表示右對齊輸出
* 0:有0表示指定空位填0,如省略表示指定空位不填
* m.n:m指域寬,即對應的輸出項在輸出設備上所占的字符數;n指精度,用於說明輸出的實型數的小數位數,未指定n時,隱含的精度為n=6位
* l,h:l對整型指long型,對實型指double型;h用於將整型的格式字符修正為short型
*/
printf格式字符
printf("%-m.nf", i); /* d格式:用來輸出十進制整數。有以下幾種用法: * %d:按整型數據的實際長度輸出。 * %md:m為指定的輸出字段的寬度。如果數據的位數小於m,則左端補以空格,若大於m,則按實際位數輸出。 * o格式:以無符號八進制形式輸出整數。對長整型可以用%lo格式輸出。同樣也可以指定字段寬度用%mo格式輸出。 * x格式:以無符號十六進制形式輸出整數。對長整型可以用%lx格式輸出。同樣也可以指定字段寬度用%mx格式輸出。 * u格式:以無符號十進制形式輸出整數。對長整型可以用%lu格式輸出。同樣也可以指定字段寬度用%mu格式輸出。 * c格式:輸出一個字符。 * s格式:用來輸出一個串。有以下幾種用法: * %s:例如:printf("%s", "CHINA")輸出字符串CHINA * %ms:輸出的字符串占m列,如果字符串本身長度大於m,則突破獲m的限制,將字符串全部輸出。若串長小於m,則左補空格。 * %-ms:如果串長小於m,則在m列范圍內,字符串向左靠,右補空格。 * %m.ns:輸出占m列,但只取字符串中左端n個字符。這n個字符輸出在m列的右側,左補空格。 * %-m.ns:其中m,n含義同上,n個字符輸出在m列范圍的左側,右補空格。如果n>m,則自動取n值,即保證n個字符正常輸出。 * f格式:用來輸出實數(包括單、雙精度),以小數形式輸出。有以下幾種用法: * %f:不指定寬度,整數部分全部輸出並輸出6位小數。 * %m.nf:輸出共占m列,其中有n位小數,若數值寬度小於m左端補空格。 * %-m.nf:輸出共占m列,其中有n位小數,若數值寬度小於m右端補空格。 * e格式:以指數形式輸出實數。可用以下形式: * %e:數字部分(又稱尾數)輸出6位小數,指數部分占5位或4位。 * %m.ne,%-m.ne:m,n和-字符含義與前相同。此處n指數據的數字部分的小數位數,m表示整個輸出數據所占的寬度。 * g格式:自動選f格式或e格式中較短的一種輸出,且不輸出無意義的零。
*/
可變寬度參數
對於m.n
的格式還可以用如下方法表示:
char ch[20]; printf("%*.*s\n",m,n,ch);
前邊的*
定義的是總的寬度,后邊的定義的是輸出的個數。分別對應外面的參數m,n
。這種方法的好處是可以在語句之外對參數m,n
賦值,從而控制輸出格式。
轉自:https://blog.csdn.net/u011475134/article/details/77075408