【发布时间】:2018-06-28 16:43:43
【问题描述】:
我正在处理加密货币 RPC 并接收 json 数据,如下所示:
{
...
"amount": 1.34000000,
"confirmations": 230016,
"spendable": true,
"solvable": true
...
}
使用Jsoncpp 库或json11 获取解析为double 的数字。发生这种情况时,由于双精度问题,结果为:1.3400000000000001。一般来说,这对金融交易来说是灾难性的并且是不可接受的。
我已经有一个定点库,它可以接受一个有效的字符串并在内部将其视为一个整数。有没有办法让 Jsoncpp(或任何其他 json 库)将选定的数字 json 值作为字符串,以便我可以以固定精度正确对待它们?
【问题讨论】:
-
我不确定,但您可能可以运行预解析并将
"amount": 1.34000000更改为"amount": "1.34000000" -
@NathanOliver 当然。这将是我最终会做的一个 hack。
-
如果您将值存储为双精度值,那么即使您将值解析为字符串,这种情况也总会发生。一旦你把它变成一个双精度浮点数就有一个有限的分辨率。这就是金融应用程序不使用实数的原因(它们使用整数或 BCD(二进制编码的小数))。您可以乘以
100000000并存储为整数。 -
@MartinYork 你似乎误解了发生了什么。请允许我解释一下。在将数字乘以 10000000 后存储数字......基本上称为“定点精度”,这是我在问题中提到的(例如,比特币是如何运作的,其中最小的可交易整数单元被称为聪)。我不想存储在双,永远。问题是我想直接从字符串到定点精度,而不必经过双精度,所有 json 库似乎都在未经我同意的情况下这样做。
标签: c++ json double fixed-point jsoncpp