C++:如何在没有舍入,截断或填充的情况下从Float转换为String?

Azh*_*bal 6 c++ floating-point

我遇到了问题,无法解决问题.需要大师的帮助.以下是示例代码: -

float f=0.01f;
printf("%f",f);
Run Code Online (Sandbox Code Playgroud)

如果我们在调试期间检查变量中的值,则f包含'0.0099999998'值,printf的输出为0.010000.

一个.有没有办法可以强制编译器为float类型的变量赋值?

湾 我想将float转换为字符串/字符数组.怎么可能只将完全相同的值转换为字符串/字符数组.我想确保没有填充零,没有填充不需要的值,数字没有变化,如上例所示.

Mar*_*som 6

除了极少数的值(例如0.25)之外,不可能使用基数2值准确地表示基数10十进制数.为了得到你需要的东西,你必须从float/double内置类型切换到某种十进制数字包.


Red*_*ing 2

看一下这个 C++ 参考。具体来说,关于精度的部分:

float blah = 0.01;
printf ("%.2f\n", blah);
Run Code Online (Sandbox Code Playgroud)