问题描述
我和 C 似乎对这里的预期输出意见不一。
我有:
struct r_struct {
int r_i;
float r_f,r_f2;
};
struct r_struct r;
r.f = 100.0;
[...]
printf("f is A:%f B:%d,C:%d,D:%d\n",r.f,r.f_lhzr / 1,(int)r.f);
我得到这个输出:
f is A:100.000000 B:0,C:1079574528,D:0
我希望得到这个输出,因为应该以所有三种方式将浮点数转换为整数:
f is A:100.000000 B:100,C:100,D:100
这里有人能解释一下吗?
解决方法
来自 printf()
的规范,例如https://en.cppreference.com/w/cpp/io/c/fprintf
如果任何参数在默认转换后不是相应转换说明符期望的类型,或者如果参数少于格式要求的数量,行为未定义。
您有浮点值并且只将一个值转换为 int
。
您对浮点数使用 "%d"
说明符,即任何可预测或可解释行为的结束,适用于所有输出和任何其他行为,不仅适用于非强制转换值。
(SomeProgrammerDude 在评论中指出了 speficier 和 type 之间的对比。我在这里参考 spec 添加了 UB 方面。)