在编程中,经常用到的一个结果转换就是两个int类型变量相除的结果为了保留精确度而转换为float或者double类型,但是这个地方最容易令人犯错误的是,如果使用如下的类型转换方式,转换时是将两个int类型变量先相除得到一个int类型结果,再将这个int类型结果转换为float或者double类型,而不是直接计算保留带有精确度的结果。
int main ()
{
int x = 50;
int y = 12;
cout << x / y << endl;
cout << (float) (x / y) << endl; // 实际上并未达到预期效果
cout << (double) (x / y) << endl; // 实际上并未达到预期效果
cout << (double) x / (double) y << endl;
return 0;
}
4
4
4
4.16667
C++类型转换陷阱
本文通过一个C++示例详细解析了整数除法转换为浮点数的常见误区,强调了正确转换方法的重要性,避免精度损失。
3824

被折叠的 条评论
为什么被折叠?



