printf如何处理float参数与处理double参数的方式完全相同?

bar*_*nos 1 c floating-point printf

直到最近,我才想到:

  • printf("%f",x) 将尝试从堆栈中读取4字节的浮点值.

  • printf("%lf",x) 会尝试从堆栈中读取一个8字节的浮点值.

但是,下面的代码似乎产生了正确的输出:

float  f = 1234.5;
double d = 12345678.9;
printf("Output = %u %u\n",sizeof(f),sizeof(d)); // Output = 4 8
printf("Output = %.1f %.1f\n",f,d);             // Output = 1234.5 12345678.9
Run Code Online (Sandbox Code Playgroud)

我相信它证明printf("%f",x)从堆栈读取一个8字节的浮点值.

这是因为两个值都正确打印,但12345678.9太大而无法放入4字节变量.

现在我的问题是:当printf使用4字节float变量调用时,编译器如何知道double在将其推入堆栈并调用之前应将其转换为8字节值printf

在调用带浮点参数的函数时,这是标准的一部分吗?

谢谢

Car*_*rum 7

编译器如何知道在将其推入堆栈并调用printf之前应将其转换为8字节的双精度值?

它不必知道何时做 - 它总是这样做; 它是默认参数促销的一部分.

在调用带浮点参数的函数时,这是标准的一部分吗?

不,只是可变的.