相关疑难解决方法(0)

浮点数学是否破碎?

请考虑以下代码:

0.1 + 0.2 == 0.3  ->  false
Run Code Online (Sandbox Code Playgroud)
0.1 + 0.2         ->  0.30000000000000004
Run Code Online (Sandbox Code Playgroud)

为什么会出现这些不准确之处?

language-agnostic math floating-point floating-accuracy

2798
推荐指数
28
解决办法
28万
查看次数

通过Swift 4中的JSONDecoder传递数字时失去精度

我正在向我们的服务器发送一些JSON数据,并且在使用新的Swift 4 JSONDecoder编码某些值时出现问题.以这个游乐场为例:

import Foundation

struct QuantyTest: Codable {
    var name: String
    var value: Float
}

let json = """
[
    {
        "name": "Length",
        "value": 9.87
    },
    {
        "name": "Width",
        "value": 9.95
    }
]
""".data(using: .utf8)!

let decoder = JSONDecoder()
var size = try decoder.decode([QuantyTest].self, from: json)
let encoder = JSONEncoder()
var encodSize = try? encoder.encode(size)
print(String(data: encodSize!, encoding: .utf8)!)
Run Code Online (Sandbox Code Playgroud)

所以我首先解码JSON并打印出结果(大小).输出看起来像这样:

[{name "Length", value 9.87}, {name "Width", value 9.95}]
Run Code Online (Sandbox Code Playgroud)

一切都很好,但是当我使用Swift JSONEncoder将(大小)编码回JSON时,我得到以下输出:

[{"name":"Length","value":9.869999885559082},{"name":"Width","value":9.9499998092651367}]
Run Code Online (Sandbox Code Playgroud)

我已经尝试将值更改为十进制或双倍但我有类似的问题,十进制输出如下所示:

[{"name":"Length","value":9.869999999999997952},{"name":"Width","value":9.95}]
Run Code Online (Sandbox Code Playgroud)

并作为双重:

[{"name":"Length","value":9.8699999999999992},{"name":"Width","value":9.9499999999999993}]
Run Code Online (Sandbox Code Playgroud)

我知道浮点数,双精度数或十进制数不是超精确的,但我不明白为什么输出窗口在使用float时显示正确的值,直到我通过JSONEncoder.我不确定如何绕过这一个,任何建议将不胜感激.

json ios swift4

8
推荐指数
0
解决办法
1292
查看次数