解决方法:STM32使用cJSON解析数据只能解析有限个字段解决办法

一、问题:

在STM32F407ZET6上移植cJSON库后解析某些数据会出错:

正确解析的数据:

{"pkg":"setAirCondition","timeStamp":1705395589,"deviceID":"abcd12345678","sensorId":"AIR01","add":14}

错误解析的数据:

{"pkg":"addSensor","timeStamp":1705395589,"deviceId":"abcd12345678","sensorType":"Settlement","sensorId":"SETTLE01","add":16,"model":"SETTLE100"}

尝试去掉部分数据后可以解析:

{"pkg":"addSensor","timeStamp":1705395589,"deviceId":"abcd12345678","sensorType":"Settlement","sensorId":"SETTLE01"}

二、原因:

查找资料,进行多次尝试后发现,当解析较大的JSON数据时,可能会遇到内存溢出的问题。这JSON库在解析过程中需要分配足够的内存来保存解析结果。

三、解决办法:

解决这个问题的方法之一是增加系统可用的内存限制。

修改STM32启动文件:startup_stm32f40_41xxx.s

1、堆(Heap): 堆是用于动态内存分配的区域,用来存储程序运行时动态创建的变量和数据结构。在单片机中,堆的大小通常是固定的,由编译器或链接器决定。堆的分配和释放通常是通过一些特定的堆管理函数(如malloc和free)来实现的。

2、栈(Stack): 栈是用于存储函数调用和局部变量的区域。每当一个函数被调用时,函数的返回地址、参数和局部变量都会被压入栈中,形成一个栈帧(Stack Frame)。当函数执行完毕后,栈帧会被弹出,恢复之前的执行状态。栈的大小通常是固定的,由编译器在编译时确定。

注意!!!

在单片机中,堆和栈的分配和管理是由编译器和链接器完成的。通常,堆的大小可以在链接器脚本中进行配置,而栈的大小可以在编译器或链接器的设置中进行调整。

需要注意的是,由于单片机的资源有限,堆和栈的大小都是受限的。过大的堆或栈大小可能会导致内存溢出或内存碎片化等问题。因此,在进行单片机编程时,需要合理地管理和分配堆和栈的大小,避免出现内存相关的问题。

  • 栈区(stack):由编译器自动分配和释放,存放函数的参数值、局部变量的值等,其操作方式类似于数据结构中的栈。
  • 堆区(heap):一般由程序员分配和释放,若程序员不释放,程序结束时可能由操作系统回收。分配方式类似于数据结构中的链表。

增大空间后问题解决!!!

  • 8
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

隐居工程师

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

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

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

打赏作者

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

抵扣说明:

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

余额充值