gpt4 book ai didi

c - 使用 %d 或 %i 进行类型转换后进行打印会产生意外的输出

转载 作者:行者123 更新时间:2023-11-30 20:51:28 24 4
gpt4 key购买 nike

我正在四舍五入一些值,然后打印它们。当我使用 %f 选项时,它们会正确打印,但使用 %d 或 %i 选项(即使在将舍入值转换为 int 之后)会给出奇怪的输出,我无法弄清楚其中的原因。

非常感谢任何帮助!

当我使用 %f 时:

i = 0;

while(i < n_shapes)
{
ll_x[i] = (int)round((ll_x[i] - min_x)/pitch_x);
ll_y[i] = (int)round((ll_y[i] - min_y)/pitch_y);
ur_x[i] = (int)round((ur_x[i] - min_x)/pitch_x);
ur_y[i] = (int)round((ur_y[i] - min_y)/pitch_y);
printf("%f,%f,%f,%f\n", ll_x[i], ll_y[i], ur_x[i], ur_y[i]);
i++;
}

输出:

115.000000,94.000000,115.000000,101.000000
116.000000,51.000000,117.000000,58.000000
116.000000,60.000000,117.000000,67.000000
116.000000,69.000000,117.000000,75.000000
116.000000,77.000000,117.000000,84.000000
116.000000,86.000000,117.000000,93.000000
116.000000,94.000000,117.000000,101.000000

现在,使用 %d(或 %i):

i = 0;

while(i < n_shapes)
{
ll_x[i] = (int)round((ll_x[i] - min_x)/pitch_x);
ll_y[i] = (int)round((ll_y[i] - min_y)/pitch_y);
ur_x[i] = (int)round((ur_x[i] - min_x)/pitch_x);
ur_y[i] = (int)round((ur_y[i] - min_y)/pitch_y);
printf("%d,%d,%d,%d\n", ll_x[i], ll_y[i], ur_x[i], ur_y[i]);
i++;
}

输出:

1079590912,0,6,-1
1078788096,0,5,-1
1079033856,0,6,-1
1079164928,0,6,-1
1079312384,0,6,-1
1079459840,0,6,-1
1079590912,0,6,-1

谢谢!

编辑:是的,我意识到在 printf 中使用 (int) 可以给我正确的输出。我很好奇当我不这样做时我得到的值(value)观。当我使用 %d 而不在 printf 中进行转换时,我的输出是什么意思?

最佳答案

这是未定义的行为。您需要使用正确的类型说明符。

printf 无法验证您传递给它进行打印的参数类型是否与其相应的格式说明符相匹配。编译器在传递这些参数之前执行特定于类型的转换,因此 printf 期望对于每个 %f if 会找到一个 double ( float 也会转换为 double),并且对于每个 %d 它将找到一个 int。您的代码为该 %d 说明符传递了一个 double 转换值,这会导致未定义的行为。

请注意,在分配给 float 之前,将 floatdouble 表达式转换为 int >double 变量不会改变数字的表示形式。它所做的只是截断小数部分。表示形式保持不变。换句话说,如果你这样做

double x = 12.345;
double y = (int)x;

与此相同

double x = 12.345;
double y = (double)((int)x);

因为在这种情况下,编译器知道变量y的类型,并为您插入缺少的强制转换。

关于c - 使用 %d 或 %i 进行类型转换后进行打印会产生意外的输出,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31756409/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com