CJson-修改浮点数的位数

本文探讨了在使用CJSON库时,如何处理浮点数转换为字符串时的精度问题。默认的%1.15g格式可能导致不期望的精度损失。解决方案包括直接修改库函数或使用cJSON_CreateRaw()结合自定义的浮点数格式化。通过自定义格式,可以确保浮点数以指定精度呈现。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

现状

调用cJSON_Print()将组成的json转为字符串格式时,对于浮点数的位数是不固定的
length = sprintf((char*)number_buffer, "%1.15g", d);
源代码里用的是%1.15g,代表输出字符最少一位,最大15位,自动选择%e%f中合适的表示法。

  1. %g用于打印浮点型数据时,会去掉多余的零,至多保留六位有效数字(不同于%e的默认保留小数点后6位)
  2. 当%g用于打印超过6位的浮点型数据时,因为精度问题,%f不得不输出一个不精确的超过六位的数字,%e也是同样,而%g此时会选择%e格式进行输出,并且按第一条要求,去掉多余的零,并且四舍五入到6位数字。这是《C Primer Plus》中所说的超过精度的时候的情况。

解决方案

  1. 直接修改print_number()函数
    这样的更改会造成全局影响。

  2. 使用cJSON_CreateRaw()

 char num_string[26]={0};
 float number = 1.23456;

 /* 自己将浮点数转换成字符串 */
 snprintf(num_string,sizeof(num_string),"%1.3f",number);
 /* 将字符串传入,这样打印时就会打印成你自己处理的格式的字符串 */
 cJSON_CreateRaw(num_string);
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

tangYi0_0

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值