现状
调用cJSON_Print()将组成的json转为字符串格式时,对于浮点数的位数是不固定的
length = sprintf((char*)number_buffer, "%1.15g", d);
源代码里用的是%1.15g,代表输出字符最少一位,最大15位,自动选择%e或%f中合适的表示法。
- %g用于打印浮点型数据时,会去掉多余的零,至多保留六位有效数字(不同于%e的默认保留小数点后6位)
- 当%g用于打印超过6位的浮点型数据时,因为精度问题,%f不得不输出一个不精确的超过六位的数字,%e也是同样,而%g此时会选择%e格式进行输出,并且按第一条要求,去掉多余的零,并且四舍五入到6位数字。这是《C Primer Plus》中所说的超过精度的时候的情况。
解决方案
-
直接修改
print_number()函数
这样的更改会造成全局影响。 -
使用
cJSON_CreateRaw()
char num_string[26]={0};
float number = 1.23456;
/* 自己将浮点数转换成字符串 */
snprintf(num_string,sizeof(num_string),"%1.3f",number);
/* 将字符串传入,这样打印时就会打印成你自己处理的格式的字符串 */
cJSON_CreateRaw(num_string);
CJSON:浮点数精度控制与字符串转换
本文探讨了在使用CJSON库时,如何处理浮点数转换为字符串时的精度问题。默认的%1.15g格式可能导致不期望的精度损失。解决方案包括直接修改库函数或使用cJSON_CreateRaw()结合自定义的浮点数格式化。通过自定义格式,可以确保浮点数以指定精度呈现。
630

被折叠的 条评论
为什么被折叠?



