可變參數函數將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中文網其他相關文章!