我怎么能准确地将双点数正常化为整数
how I can normal a double point number to a int number exacly?
我有一个通过tcp连接的客户端程序将数据发送到服务器。在客户端中,我需要向服务器发送一个规范化的十进制数以进行规范化 I 乘数十进制数到 100,000,然后将其发送到服务器,但我在服务器中得到错误的数字。例如。
double price;
我将其从 Gui 设置为 74.40
cout<<price; ---> 74.40
当我串行我的对象时,我发送
#define Normal 100000
int tmp = price*Normal;
oDest<<tmp;
在wireshrk中,我看到客户端发送了7439999。
为什么会这样?我怎样才能解决这个问题?
不要将任何内容存储为浮点值。请改用有理数,或使用固定点值。浮点值(如double
)基本上是"作弊",以便将大量可能的值固定到合理的内存块中,并且它们必须做出妥协才能做到这一点。
如果您正在存储财务价值,请考虑存储便士或美分或任何最小面额
这是
由于浮点精度错误造成的。您可以添加一些舍入:
int tmp = (price + 0.5/Normal)*Normal;
由于
浮点数无法准确表示十进制数,因此在将数字转换为整数时,需要对数字进行舍入。
int tmp = price*Normal + 0.5;
相关文章:
- 如何反转整数参数包
- enum是C++中的宏变量还是整数变量
- 努力将整数转换为链表。不知道我在这里做错了什么
- 整数不会重复超过随机数
- 在C++中手动调整数组大小
- 检查输入是否不是整数或数字
- C++使用整数的压缩数组初始化对象
- 在C++中,将大的无符号浮点数四舍五入为整数的最佳方法是什么
- 将"打开的CV图像"中的"颜色"转换为整数格式
- 通过套接字[TCP]传输数据 如何在C / C ++中打包多个整数并使用send() recv()传输数据
- 如何只允许用户输入正整数
- 如何在c++中从文本文件中逐行读取整数
- C++:如何循环通过向量中的整数元素
- 我可以信任表示整数的浮点或双精度来保持精度吗
- 序列化,没有库的整数,得到奇怪的结果
- 在一定长度后从数组中打印时缺少整数
- std::当在256字节边界上写入整数时,流的奇怪行为
- 内联程序集printf将整数解释为地址
- 是否基于数组B整数打印数组A中的整数
- 如何在C++中将整数转换为其数字数组