PHP7 json_encode() 浮点小数溢出错误

原因已找到, 该现象只出现在PHP 7.1+版本上

建议使用默认值 serialize_precision = -1 即可

事情是这样的,项目里发现一个奇怪的现象,json_encode一个带浮点价格的数据, 出现溢出, 比如:

bash 复制代码
echo json_encode(277.2);
// 输出结果为: 277.199999999999989

这明显是不能接受的, 数据虽然很接近, 但毕竟已经变更了

下意识地认为这是php的一个bug, 不能准确地json序列化一个浮点小数

这个问题google了半天竟然也无果, 因此json_encode数据里有小数的时候, 记得先number_format()转化成字符串.

相关推荐
сокол11 小时前
【网安-Web渗透测试-漏洞系列】逻辑漏洞(或越权漏洞)
web安全·php
сокол15 小时前
【网安-Web渗透测试-漏洞系列】XXE漏洞
xml·web安全·php
数据知道17 小时前
PostgreSQL:如何直接在数据库中查询 CSV/JSON文件?
数据库·postgresql·json
сокол2 天前
【网安-Web渗透测试-漏洞系列】文件包含&下载读取
web安全·php
程序员林北北2 天前
【前端进阶之旅】一种新的数据格式:TOON
前端·javascript·vue.js·react.js·typescript·json
月明长歌2 天前
网络原理初识:从“几台电脑各干各的”到“数据包跨网段飞奔”的一整套思维模型
网络·计算机网络·电脑·php
сокол2 天前
【网安-Web渗透测试-漏洞系列】文件上传漏洞
web安全·php
сокол2 天前
【网安-Web渗透测试-漏洞系列】序列化漏洞
web安全·php
明月_清风2 天前
向 Native 借力:深度拆解 SIMD 加速与 Node.js 异步原生解析
前端·json
love530love2 天前
【OpenClaw 本地实战 Ep.3】突破瓶颈:强制修改 openclaw.json 解锁 32k 上下文记忆
人工智能·windows·json·cuda·lm studio·openclaw·context length