C語言 printf詳解
1
.轉換說明符
%a(%A)
浮點數、十六進位制數字和
p-(P-)
記數法
(C99)
%c
字元
%d
有符號十進位制整數
%f
浮點數
(
包括
float
和
doulbe)
%e(%E)
浮點數指數輸出
[e-(E-)
記數法
]
%g(%G)
浮點數不顯無意義的零
"0"
%i
有符號十進位制整數
(
與
%d
相同
)
%u
無符號十進位制整數
%o
八進位制整數
e.g. 0123
%x(%X)
十六進位制整數
<?xml:namespace prefix = st1 />() e.g. 0x1234
%p
指標
%s
字串
%% "%"
2
.標誌
左對齊:
"-" e.g. "%-20s"
右對齊:
"+" e.g. "%+20s"
空格:若符號為正,則顯示空格,負則顯示
"-" e.g. "% "
#
:對
c,s,d,u
類無影響;對
o
類,在輸出時加字首
o
;對
x
類,在輸出時加字首
0x
;
對
e,g,f
類當結果有小數時才給出小數點。
3
.格式字串(格式)
[標誌][輸出最少寬度][.精度][長度]型別
"
%
-md"
:左對齊,若
m
比實際少時,按實際輸出。
"%m.ns"
:輸出
m
位,取字串
(
左起
)n
位,左補空格,當
n>m or m
省略時
m=n
e.g. "%7.2s"
輸入
CHINA
輸出
" CH"
"%m.nf"
:輸出浮點數,
m
為寬度,
n
為小數點右邊數位
e.g. "%"
輸入
3852.99
輸出
3853.0
長度:為h短整形量
,
l為長整形量
printf
的格式控制的完整格式:
% - .n l
或
h
格式字元
下面對組成格式說明的各項加以說明:
①
%
:表示格式說明的起始符號,不可缺少。
②
-
:有
-
表示左對齊輸出,如省略表示右對齊輸出。
③
:有
表示指定空位填
0,
如省略表示指定空位不填。
④
m.n
:
m
指域寬,即對應的輸出項在輸出裝置上所佔的字元數。
N
指精度。用於說明輸出的實型數的小數位數。為指定
n
時,隱含的精度為
n=6
位。
⑤
l
或
h:l
對整型指
long
型,對實型指
double
型。
h
用於將整型的格式字元修正為
short
型。
一個
h
表示
short
,即
short int
兩個
h
表示
short short
,即
char
。
%hhx
用於輸出
char
%hx
用於輸出
short int.
---------------------------------------
格式字元
格式字元用以指定輸出項的資料型別和輸出格式。
①
d
格式:用來輸出十進位制整數。有以下幾種用法:
%d
:按整型資料的實際長度輸出。
%md
:
m
為指定的輸出欄位的寬度。如果資料的位數小於
m
,則左端補以空格,若大於
m
,則按實際位數輸出。
%ld
:輸出長整型資料。
②
o
格式:以無符號八進位制形式輸出整數。對長整型可以用
"%lo"
格式輸出。同樣也可以指定欄位寬度用
“%mo”
格式輸出。
例:
main()
{ int a = -1;
printf("%d, %o", a, a);
}
執行結果:
-1,177777
程式解析:
-1
在記憶體單元中(以補碼形式存放)為
(1111111111111111)2
,轉換為八進位制數為
(177777)8
。
③
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
:輸出共佔
n
列,其中有
n
位小數,如數值寬度小於
m
右端補空格。
⑧
e
格式:以指數形式輸出實數。可用以下形式:
%e
:數字部分(又稱尾數)輸出
6
位小數,指數部分佔
5
位或
4
位。
%m.ne
和
%-m.ne
:
m
、
n
和
”-”
字元含義與前相同。此處
n
指資料的數字部分的小數位數,
m
表示整個輸出資料所佔的寬度。
⑨
g
格式:自動選
f
格式或
e
格式中較短的一種輸出,且不輸出無意義的零。
---------------------------------------
關於
printf
函式的進一步說明:
如果想輸出字元
"%",
則應該在
“
格式控制
”
字串中用連續兩個
%
表示,如
:
printf("%f%%", 1.0/3);
輸出
0.333333%
。
---------------------------------------
對於單精度數,使用
%f
格式符輸出時,僅前
7
位是有效數字,小數
6
位.
對於雙精度數,使用
%lf
格式符輸出時,前
16
位是有效數字,小數
6
位.
由高手指點
對於
m.n
的格式還可以用如下方法表示(例)
char ch[20];
printf("%*.*s\n",m,n,ch);
前邊的
*
定義的是總的寬度,後邊的定義的是輸出的個數。分別對應外面的引數
m
和
n
。我想這種方法的好處是可以在語句之外對引數
m
和
n
賦值,從而控制輸出格式。
--------------------------------------------------------------------------------
今天
()
又看到一種輸出格式
%n
可以將所輸出字串的長度值賦紿一個變數
,
見下例
:
int slen;
printf("hello world%n", &slen);
執行後變數被賦值為 11
另外:
1
、格式輸出函式的一般形式
函式原型:
int printf(char * format[,argument,…]);
函式功能:按規定格式向輸出裝置(一般為顯示器)輸出資料,並返回實際輸出的字元數,若出錯,則返回負數。
它使用的一般形式為:
printf("
格式控制字串
",
輸出項列表
);
語句中
“
輸出項列表
”
列出要輸出的表示式(如常量、變數、運算子表示式、函式返回值等),它可以是
個、一個或多個,每個輸出項之間用逗號(
,
)分隔。輸出的資料可以是整數、實數、字元和字串。
"
格式控制字串
"
必須用英文的雙引號括起來,它的作用是
控制輸出項的格式和輸出一些提示資訊,例如
int i=97; printf("i=%d,%c\n",i,i);
輸出結果為:
i=97,a
語句
“printf("i=%d,%c\n",i,i);”
中的兩個輸出項都是變數
i
,但卻以不同的格式輸出,一個輸出整型數
97
,另一個輸出的卻是字元
a
,其格式分別由
“%d”
與
“%c”
來控制。
語句
“printf("i=%d,%c\n",i,i);”
的格式控制字串中
“i=”
是普通字元,他將照原樣輸出;
“%d”
與
“%c”
是格式控制符;
"\n"
是跳脫字元,它的作用是換行。
2
、格式控制
格式控制由格式控制字串實現。格式控制字串由
3
部分組成:普通字元、跳脫字元、輸出項格式說明。
(
1
)普通字元。普通字元在輸出時,按原樣輸出,主要用於輸出提示資訊。
(
2
)跳脫字元。跳脫字元指明特定的操作,如
"\n"
表示換行,
"\t"
表示水平製表等。
(
3
)格式說明部分由
“%”
和
“
格式字串
”
組成,他表示按規定的格式輸出資料。
格式說明的形式為:
%[flags][width][.prec][F|N|h|I][type]
各部分說明如下:
1. “[]” 表示 該項為 可 選項 ,即可有可無,如 printf("%d",100);
2. flags 為可選擇的標誌字元,常用的標誌字元有 :
· - —— 左 對齊輸 出,默 認為 右 對齊輸 出;
· + —— 正數 輸 出加號 (+) , 負 數 輸 出減號 (-);
· 空格 —— 正數 輸 出空格代替加號 (+) , 負 數 輸 出減號 (-) 。
1. width 為可選擇的寬度指示符 。
· 用十 進 制正整數表示 設 置 輸 出 值 得最少字元個數。不足 則補 空格,多出 則 按 實際輸 出,默 認 按 實際輸 出,例如:
· printf("%8d\n",100); printf("%6d\n",100); printf("%-8d\n",100); printf("%+8\n",100);
·
輸出結果為:
└┘└┘└┘└┘└┘100
└┘└┘└┘100 100└┘└┘└┘└┘└┘ └┘└┘└┘└┘+100
1. [.prec] 為可選的精度指示 符
· 用 “ 小數點 ” 加 “ 十 進 制正整數 ” 表示, 對 “ 整數 ” 、 “ 實數 ” 和 “ 字串 ” 的 輸 出有如下功能: 對 “ 整數 ” ,表示至少要 輸 出的數字個數,不足 補 數字 ,多 則 原 樣輸 出; 對 “ 實數 ” ,表示小數點後至多 輸 出的數字個數,不足 則補 數字 ,多 則 做舍入 處 理; 對 “ 字串 ” ,表示最多 輸 出的字元個數,不足 補 空格,多 則丟 棄。
·
例如:
printf("%8.2f\n",3.14159);
printf("%8.5f\n",3.14159);
·
輸出結果為:
└┘└┘└┘└┘3.14
└┘3.14159
1. [F|N|h|I] 為可選的輸出長度修飾符,其功能如下 :
· F —— 輸出遠指標存放的地址 ;
· N—— 輸出近指標存放的地址 ;
· h—— 輸出短整型資料的值 ;
· l—— 輸出長整型或雙精度型資料的值 。
· 例如: long n=40000;
· printf("%8ld\n",n);/* 因 為 200*200 是 長 整型資料 */
· type 為可選的格式字元,用來進行格式轉換 。
/*************************************************************************
> File Name: printf.c
> Author:
> Mail:
> Created Time: Tue 06 Nov 2018 09:13:35 AM CST
************************************************************************/
#include<stdio.h>
int main()
{
//for int
int i=30122121;
long i2=309095024l;
short i3=30;
unsigned i4=2123453;
printf("%d,%o,%x,%X,%ld,%hd,%u/n",i,i,i,i,i2,i3,i4);// 如果是: %l,%h ,則輸不出結果
printf("%d,%ld/n",i,i2);// 試驗不出 %ld 和 %d 之間的差別,因為 long 是 4bytes
printf("%hd,%hd/n/n/n",i,i3);// 試驗了 %hd 和 %d 之間的差別,因為 short 是 2bytes
//for string and char
char ch1='d';
unsigned char ch2=160;
char *str="Hello everyone!";
printf("%c,%u,%s/n/n/n",ch1,ch2,str);//unsigned char 超過 128 的沒有字元對應
//for float and double,unsigned and signed can not be used with double and float
float fl=2.566545445F;//or 2.566545445f
double dl=265.5651445;
long double dl2=2.5654441454;
//%g 沒有 e 格式,預設 6 位包括小數點前面的數 ,
//%f 沒有 e 格式,預設 6 位僅只小數點後面包含 6 位
//%e 採用 e 格式,預設 6 位為轉化後的小數點後面的 6 位
printf("%f,%e,%g,%.7f/n",fl,dl,dl,dl);
printf("%f,%E,%G,%f/n",fl,dl,dl,dl);//%F is wrong
printf("%.8f,%.10e/n",fl,dl);
printf("%.8e,%.10f/n/n/n",fl,dl);
//for point
int *iP=&i;
char *iP1=new char;
void *iP2;//dangerous!
printf("%p,%p,%p/n/n/n",iP,iP1,iP2);
// 其他知識:負號,表示左對齊(預設是右對齊); %6.3 , 6 表示寬度, 3 表示精度
char *s="Hello world!";
printf(":%s: /n:%10s: /n:%.10s: /n:%-10s: /n:%.15s: /n:%-15s: /n:%15.10s: /n:%-15.10s:/n/n/n",
s,s,s,s,s,s,s,s);
double ddd=563.908556444;
printf(":%g: /n:%10g: /n:%.10g: /n:%-10g: /n:%.15g: /n:%-15g: /n:%15.10g: /n:%-15.10g:/n/n/n",
ddd,ddd,ddd,ddd,ddd,ddd,ddd,ddd);
// 還有一個特殊的格式 %*.* , 這兩個星號的值分別由第二個和第三個引數的值指定
printf("%.*s /n", 8, "abcdefgggggg");
printf("%*.*f /n", 3,3, 1.25456f);
return 0;
}
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/31561984/viewspace-2221204/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- C語言——設計printf除錯巨集C語言除錯
- C語言#define詳解C語言
- C語言斷言assert詳解C語言
- c語言指標詳解C語言指標
- 詳解C語言函式C語言函式
- c語言列舉詳解C語言
- c語言運算子詳解C語言
- 類似於C語言的printf函式 (轉)C語言函式
- C/C++語言精髓 *和&詳解C++
- C語言-srand種子詳解C語言
- C語言指標詳解(一)C語言指標
- C語言指標詳解(二)C語言指標
- C語言 sizeof函式詳解C語言函式
- C 語言回撥函式詳解函式
- C語言可變引數詳解C語言
- C語言printf()函式:格式化輸出函式C語言函式
- C++ 的 cin/cout 為什麼比 C 語言的 scanf/printf 慢C++
- C語言 printf 格式化 輸出 右對齊補零C語言
- 基於C語言的Q格式使用詳解C語言
- c語言學習--time庫函式詳解C語言函式
- java中printf中用法詳解Java
- C語言核心之陣列和指標詳解C語言陣列指標
- C語言:記憶體位元組對齊詳解C語言記憶體
- C#語言入門詳解(劉鐵錳)---泛型C#泛型
- 詳解雙向連結串列的基本操作(C語言)C語言
- 基於C語言EOF與getchar()的使用詳解C語言
- Dart語言詳解(二)——基本語法Dart
- C語言可變引數以及printf()、sprintf()、vsprintf() 的區別與聯絡C語言
- Go 語言介面詳解(一)Go
- Go 語言閉包詳解Go
- Go 語言介面詳解(二)Go
- Drools 規則語言詳解
- c語言中sizeof詳解C語言
- c語言陣列名解釋C語言陣列
- Dart語言詳解(一)——詳細介紹Dart
- C語言 C語言野指標C語言指標
- C語言---“C語言 誰與爭鋒?”C語言
- C 語言中的 sscanf 詳解