stm32 移植cJson 注意free释放内存!!

本文介绍如何将cJSON库移植到STM32平台,并实现自定义内存分配与释放函数以避免程序运行中出现的问题。文章强调了正确使用内存释放函数的重要性。

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


如题:

关于怎么移植的网上有很多参考文档,也很简单,因为cjson只有2个文件,一个cJSON.c 一个cJSON.h文件。

我用的是原子的stm32 工程文件测试,他们有自己定义的malloc.c      malloc.h,很方便可以直接用。

需要修改的就是下面:把原本的json malloc 和free替换成我们自己的,如下代码

  static void *(*cJSON_malloc)(size_t sz) = malloc;
  static void (*cJSON_free)(void *ptr) = free;
----------------------------------------
 void *(*cJSON_malloc)(size_t sz) = mymalloc;
 void (*cJSON_free)(void *ptr) = myfree;

void cJSON_InitHooks(cJSON_Hooks* hooks)
{
    if (!hooks)
    {
        /* Reset hooks */
        cJSON_malloc = malloc;
        cJSON_free = free;
        return;
    }

    //cJSON_malloc = (hooks->malloc_fn) ? hooks->malloc_fn : malloc;
    //cJSON_free = (hooks->free_fn) ? hooks->free_fn : free;
		
    cJSON_malloc = (hooks->malloc_fn) ? hooks->malloc_fn : mymalloc;
    cJSON_free = (hooks->free_fn) ? hooks->free_fn : myfree;
}

通过上面这样修改就可以运行例子了。

代码运行可以,但是有个问题要注意:

我们在 运行  p=cJSON_Print(root);   
 后务必要要进行如下释放操作

cJSON_Delete(root);   

free(p)

关于free这点特别加粗注意,我被这个问题困扰两天,默认网上的介绍都是这样写的,编译代码也没要出现错误。

其实不对的,应该使用myfree(p); 这个函数才能给真正释放内存,要不然程序跑几分钟就卡死了,这个特别要注意。喜欢做验证的朋友可以自己测试下。

这问题不容易发现,我几乎快放弃cjson了。还好最后解决了。






### STM32F4 上移植 CJSON 库 #### 准备工作 为了成功在STM32F4系列微控制器上移植CJSON库,需准备如下工具和资源: - 正点原子探索者STM32F4开发板[^2]。 - 安装必要的软件环境,如STM32CubeMX用于初始化配置,以及编译器(如GCC ARM Embedded或Keil MDK)。 #### 下载并集成CJSON库 获取最新版本的CJSON源代码。可以从[CJSON GitHub仓库](https://github.com/DaveGamble/cJSON)下载稳定版压缩包或者克隆整个Git仓库到本地计算机。解压文件夹并将`cJSON.c`与`cJSON.h`两个核心文件复制至项目的源目录下。 #### 配置项目工程 利用STM32CubeMX创建新的工程项目,并按照需求设置时钟树、外设等参数。完成硬件抽象层(HAL)的基础配置之后,在IDE内添加上述提到的CJSON源文件路径以便参与编译链接过程。 #### 编写测试程序 编写简单的应用程序来验证CJSON功能是否正常运作。下面给出一段Python风格伪代码作为参考实现思路: ```python import json # 假定此处为嵌入式环境下对应的json解析模块 data = { "sensor": "temperature", "value": 28.5, } # 将字典转换成字符串形式 json_str = json.dumps(data) print(f"Generated JSON string is {json_str}") parsed_data = json.loads(json_str) print(f"Parsed back data structure: sensor={parsed_data['sensor']}, value={parsed_data['value']}") ``` 实际应用中应替换为相应的C语言API调用来操作CJSON对象。例如: ```c #include "cJSON.h" int main(void){ /* 初始化系统 */ cJSON *root = NULL; char *out = NULL; root = cJSON_CreateObject(); cJSON_AddStringToObject(root, "sensor", "temperature"); cJSON_AddNumberToObject(root, "value", 28.5); out = cJSON_Print(root); printf("Generated JSON string is %s\n", out ? out : ""); cJSON_Delete(root); // 清理内存 return 0; } ``` #### 注意事项 - **内存管理**:考虑到嵌入式系统的特殊性,在使用动态分配函数(`malloc`, `free`)时要特别小心处理可能出现的碎片化问题;如果可能的话尝试静态分配所需缓冲区大小。 - **错误检测**:始终检查返回的状态码以确认每一步骤都按预期执行完毕,尤其是在构建复杂的JSON结构体期间更应该如此做。 - **性能优化**:对于资源受限设备而言,减少不必要的计算开销非常重要。可以考虑裁剪掉不使用的特性选项从而减小程序体积。
评论 9
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值