以下打印基本的數據類型, 如int, char, float等, 最後兩行是以八進制和十六進制打印數字10
int aint=10;
float afloat=1.1;
double adouble=2.2;
char achar='a';
char*str="string";
printf("int aint=%d\n",aint);
printf("float afloat=%f\n",afloat);
printf("double adouble=%f\n",adouble);
printf("char achar=%c\n",achar);
printf("char *str=%s\n",str);
printf("octal int aint=%o(8)\n",aint);
printf("hex int aint=%x(16)\n",aint)
windows gcc輸出:
設置每個整數占10個位置, 默認為右對齊
如果數字的長度比設置的寬度大, 那麼會忽略我們設置的輸出寬度
int a=1,b=2,c=3,d=4;
printf("%10d, %10d\n", a, b);
printf("%10d, %10d\n", a, b);
windows gcc輸出:
對齊,填充
在上一個例子中, 設置寬度後默認是右對齊, 我們可以在10前加一個-(減號)設置為左對齊
在上一個例子中, 當整數的長度少於我們設置的寬度時會用空格去填充,我們 可以在10前加一個0用0進行填充
int a=1,b=2,c=3,d=4;
printf("%-10d, %-10d\n", a, b);
printf("%010d, %010d\n", a, b);
windows gcc輸出:
在時浮點數字後面跟的小數點很長,如pi=3.1415… , 但我們只想看小數點後2位或3位
%.xf, 其中的x就是我們要保留的小數點後的位數,在x前面有個點號為精度標志
double pi=3.1415926;
printf("%.3f\n",pi);
printf("%.6f\n",pi);
windows gcc輸出:
%lld 用於輸出像long long這類超長的整數, 中間的兩個ll是long long的縮寫
longlong a=123456789012345;
printf("%lld\n", a);
printf的格式化工作: %[對齊,填充,正負][輸出寬度][精度][超長整數]基本類型
中括號括著的表示可有可無, 百分號和基本類型這兩部分不能為空
在[對齊,填充,正負]中的正負用+(加號)來表示, 如果整數為正就顯示一個+,如果為負就顯示一個-
收尾例子: 顯示浮點數前的加號; 不顯示浮點數的小數部分
float a=10.01;
printf("%+f\n",a);
printf("%+.0f\n",a)