問:有人告訴我不能在printf中使用%lf。為什麼printf()用%f輸出double型,而scanf卻用%lf呢?
答:printf的%f說明符的確既可以輸出float型又可以輸出double型。 根據"預設引數提公升"規則(在printf這樣的函式的可變引數列表中 ,不論作用域內有沒有原型,都適用這一規則)float型會被提公升為double型。因此printf()只會看到雙精度數。參見問題15.2。
對於scanf,情況就完全不同了,它接受指標,這裡沒有類似的型別提公升。(通過指標)向float儲存和向double儲存大不一樣,因此,scanf區別%f和%lf。
下表列出了printf和scanf對於各種格式說明符可以接受的引數型別。
格式printf
scanf
%c int
char *
%d, %i
int
int *
%o, %u, %x
unsigned int
unsigned int *
(續)格式
printf
scanf
%ld, %li
long int
long int *
%lo, %lu, %lx
unsinged long int
unsigned long int *
%hd, %hi
int
short int *
%ho, %hu, %hx
unsigned int
unsigned short int *
%e, %f, %g
double
float *
%le, %lf, %lg
n/a
double *
%s char *
char *
%[...]
n/a
char *
%p void
void **
%n int *
int *
%% none
none
(嚴格地講,%lf在printf下是未定義的,但是很多系統可能會接受它。要確保可移植性,就要堅持使用%f。)
printf中輸出double的佔位符
問 有人告訴我不能在printf中使用 lf。為什麼printf 用 f輸出double型,而scanf卻用 lf呢?答 printf的 f說明符的確既可以輸出float型又可以輸出double型。根據 預設引數提公升 規則 在printf這樣的函式的可變引數列表中 不論作用域內有沒有原型,都適用這...
printf輸出double型別資料遇到的問題
以下內容 背景 今天在用c語言寫程式時遇到了乙個問題 printf lf double r 竟然輸出亂碼 0.000000 瀏覽了幾十個網頁之後,大致找到了問題原因。結論 在c語言中,double型別的讀入必須用 lf 輸出必須用 f 解釋 double和float的精度是不同的,故儲存空間也是不同...
c語言double型別printf問題
背景 今天在用c語言寫程式時遇到了乙個問題 printf lf double r 竟然輸出亂碼 0.000000 瀏覽了幾十個網頁之後,大致找到了問題原因。結論 在c語言中,double型別的讀入必須用 lf 輸出必須用 f 解釋 double和float的精度是不同的,故儲存空間也是不同的,所以如...