首頁 >後端開發 >C++ >所有可變參數函數都會將浮點數參數增加一倍嗎?

所有可變參數函數都會將浮點數參數增加一倍嗎?

Patricia Arquette
Patricia Arquette原創
2024-11-19 00:06:02576瀏覽

Do All Variadic Functions Promote Float Arguments to Double?

可變參數函數將printf() 中的浮點參數提升為Double

在C 和 C 語言中,printf()函數是一個可變參數函數它需要可變數量的參數。 printf() 的一個特殊行為是,當傳遞 float 參數時,它會在函數接收之前轉換為 double。這就提出了一個問題:所有的可變參數函數都會將 float 參數提升為 double 嗎?

答案:

是的,C 和 C 中的可變參數函數將 float 參數提升為 double。

理由:

此行為是指定的在 C99 和 C 標準中。 C99 標準草案規定,對於可變參數函數,「具有 float 類型的參數將提升為 double」。類似地,C 標準規定「要進行浮點提升的浮點類型,參數的值在呼叫之前會轉換為提升後的類型。」

此提升背後的基本原理是保持與K&R C 標準的兼容性,該標準要求在沒有原型聲明的情況下將float 參數提升為double。儘管並不總是理想的,但出於向後相容性的原因保留了這種相容性。

以上是所有可變參數函數都會將浮點數參數增加一倍嗎?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn