c stof函数铸造为整数
C++ stof function cast to integer
#include <iostream>
int main()
{
int val = std::stof("4.99") * 100;
std::cout << val;
return 0;
}
我已经尝试了其他字符串,它们似乎都在正确转换,但是我不确定在幕后发生了什么,这导致了它输出498
而不是499
。在我的用例中,每个字符串最多都有2
小数点。
最近的 ieee754 float
to 4.99
是 4.9899997711181640625
。std::stof
将返回后者。
乘以100
的是498.999969482421875
,它已截断为498
。
这是恐怕浮点算术的陷阱之一。当使用不连续功能(例如float
转换为int
)时,您需要小心。在您的特定情况下使用std::lround
将有效。
进一步读取:浮点数学是否损坏?
#include <cmath>
#include <iostream>
int main()
{
auto val = std::lround(std::stof("4.99") * 100);
std::cout << val;
return 0;
}
相关文章:
- 如何反转整数参数包
- enum是C++中的宏变量还是整数变量
- 努力将整数转换为链表。不知道我在这里做错了什么
- 整数不会重复超过随机数
- 在C++中手动调整数组大小
- 检查输入是否不是整数或数字
- C++使用整数的压缩数组初始化对象
- 在C++中,将大的无符号浮点数四舍五入为整数的最佳方法是什么
- 将"打开的CV图像"中的"颜色"转换为整数格式
- 通过套接字[TCP]传输数据 如何在C / C ++中打包多个整数并使用send() recv()传输数据
- 如何只允许用户输入正整数
- 如何在c++中从文本文件中逐行读取整数
- C++:如何循环通过向量中的整数元素
- 我可以信任表示整数的浮点或双精度来保持精度吗
- 序列化,没有库的整数,得到奇怪的结果
- 在一定长度后从数组中打印时缺少整数
- std::当在256字节边界上写入整数时,流的奇怪行为
- 内联程序集printf将整数解释为地址
- 是否基于数组B整数打印数组A中的整数
- c stof函数铸造为整数