[问题] json大数字变成了科学符号

楼主: renmax (竹科學友哥)   2022-08-02 17:31:19
开发平台(Platform): (Ex: Win10, Linux, ...)
Win10
编译器(Ex: GCC, clang, VC++...)+目标环境(跟开发平台不同的话需列出)
NetBeans + Linux
额外使用到的函数库(Library Used): (Ex: OpenGL, ...)
cJson (https://github.com/DaveGamble/cJSON)
问题(Question):
如果json的资料是
{
"str": "4761739001010135",
}
读取后,将字串转成数字,使用cJSON_AddNumberToObject后
如预期的得到
{
"num": 4761739001010135
}
但是遇到尾数是零时,相同的程式码就会变成科学符号
例如,如果json的资料是
{
"str": "4761739001010010"
}
结果得到 (非预期)
{
"num": 4.76173900101001e+15
}
相关程式码如下:
cJSON *pjNode = NULL;
pjNode = cJSON_GetObjectItem(pInJson, "str");
if (pjNode != NULL)
{
cJSON_AddNumberToObject(pOutJson, "num", atoll(pjNode->valuestring));
}
感觉是大数字才会发生问题,因此想请教一下
1. 为何相同的程式码,当尾数是0时,会变成科学符号呢?
2. 如何避免/修改成一般的数字,而不是科学符号呢?
麻烦了 感谢
喂入的资料(Input):
预期的正确结果(Expected Output):
错误结果(Wrong Output):
程式码(Code):(请善用置底文网页, 记得排版,禁止使用图档)
补充说明(Supplement):
作者: Chikei ( )   2022-08-02 18:06:00
楼主: renmax (竹科學友哥)   2022-08-03 16:30:00
C大 我是使用cJSON_AddNumberToObject后 去print json内容发现 原本print出来的应该是长整数 但却显示科学符号而科学符号 并不是我想要的结果 我希望print出来后 是整数型态 您给的参考网址是取值 而不是塞值 谢谢帮忙>"<
作者: yvb   2022-08-03 16:57:00
cJSON.c 找 Try 15 decimal 看那边. %1.15g 和 %1.17g 的差别这实作似乎不符合 RFC 8259 第六节 Numbers 的最后一段.可能只参照到 RFC 4627.
作者: Chikei ( )   2022-08-04 13:44:00
人家就说cJSON不支援long long,跟取值还是塞值没关系。
楼主: renmax (竹科學友哥)   2022-08-04 14:15:00
不好意思 如果不支援long long的话 请问一下1. 上方的例子中 为何只有尾数是零 才会变成科学符号呢?2. 有什么方法 可以做到预期的结果呢?(整数长度MAX = 20)感谢y大和C大帮忙
作者: Chikei ( )   2022-08-04 15:44:00
1. 上面yvb已经回答了 2. 没有,请看完上面的issue回答
作者: Richun (解放左手的OO之力)   2022-08-05 04:43:00
51 bits换算是15.3位,长度20已经超过了,cJSON不能用。只能找其他的或是fork cJSON自己修
作者: LPH66 (-6.2598534e+18f)   2022-08-05 20:30:00
长度 20 也不能用 double 或 int64_t 来存uint64_t 只能擦边 (18446744073709551615 正好 20 位)所以任意 20 位的数字可能要建议当字串来用
楼主: renmax (竹科學友哥)   2022-08-08 15:26:00
感谢各位大大的解释 我仍然不太懂y大说的Try 15 decimal这边的意思 为何特定使用15和17 decimal来做判断呢?
作者: LPH66 (-6.2598534e+18f)   2022-08-09 03:16:00
double 的精确度是 53 bit, 数学转换对应十进制约 15.95 位所以一般可能会认为印出 1+15 位数就能足够表示一个 double但实际上如果要达成所谓的 round-trip (转成字串再转回来时要得到完全一样的 double 数值) 会需要印出 1+17 位才能使某些边界状况能够得到分辨

Links booklink

Contact Us: admin [ a t ] ucptt.com