微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

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

参见英文答案 > Why do I see a double variable initialized to some value like 21.4 as 21.399999618530273?14个
我遇到了问题,无法解决问题.需要大师的帮助.以下是示例代码: –
float f=0.01f;
printf("%f",f);

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

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

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

解决方法

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

原文地址:https://www.jb51.cc/c/117106.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐