printf中輸出double的佔位符

2022-07-24 23:00:36 字數 1219 閱讀 9874

問:有人告訴我不能在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的精度是不同的,故儲存空間也是不同的,所以如...