Toggle navigation
首页
问答
文章
积分商城
专家
专区
更多专区...
文档中心
返回主站
搜索
提问
会员
中心
登录
注册
RT-Thread一般讨论
【求助】使用cjson包后出现报内存不足的情况
发布于 2019-10-29 16:39:17 浏览:2101
订阅该版
* 本帖最后由 ssp97 于 2019-10-29 16:51 编辑 * 在使用cjson构造mqtt遗嘱的时候,出现内存不足的问题,求帮助。![微信截图_20191029163102.png](/uploads/201910/29/163627z1gawkz21km1f6r9.png) 相关cjson处理的代码如下: ``` char * cpuUuidStringGet() { char *uuid; uuid = rt_malloc(13); //sprintf(uuid,"%.8X%.8X%.8X",HAL_GetUIDw0(),HAL_GetUIDw1(),HAL_GetUIDw2()); sprintf(uuid,"%.8X%.8X%.8X",0x11223344,0x55667788,0x99AABBFF); return uuid; } char * getDeviceSn(){ return cpuUuidStringGet(); } cJSON * api_base(char * action) { cJSON *root; root = cJSON_CreateObject(); cJSON_AddStringToObject(root,"device-id",getDeviceSn()); cJSON_AddStringToObject(root,"action",action); return root; } char * api_online(char status) { cJSON *root; char *out; root = api_base("online"); cJSON_AddNumberToObject(root,"data",status); out = cJSON_PrintUnformatted(root); cJSON_Delete(root); return out; } ```mqtt启动代码片段如下: ```static char mqtt_willmsg[128]; void mq_start(void) { /* 使用 MQTTPacket_connectData_initializer 初始化 condata 参数 */ MQTTPacket_connectData condata = MQTTPacket_connectData_initializer; static char cid[20] = { 0 }; static int is_started = 0; if (is_started) { return; } /* 配置 MQTT 结构体内容参数 */ { client.uri = MQTT_URI; /* 产生随机的客户端 ID */ rt_snprintf(cid, sizeof(cid), "rtthread%d", rt_tick_get()); /* 配置连接参数 */ memcpy(&client.condata, &condata, sizeof(condata)); client.condata.clientID.cstring = cid; client.condata.keepAliveInterval = 60; client.condata.cleansession = 1; client.condata.username.cstring = MQTT_USERNAME; client.condata.password.cstring = MQTT_PASSWORD; extern char * api_online(char status); char * out = api_online(0); // rt_kprintf("1,%d ",rt_strlen(out)); memcpy(mqtt_willmsg,out,128); rt_free(out); // rt_kprintf("2 "); /* 配置 MQTT 遗言参数 */ client.condata.willFlag = 1; client.condata.will.qos = 1; client.condata.will.retained = 0; client.condata.will.topicName.cstring = MQTT_PUBTOPIC; client.condata.will.message.cstring = mqtt_willmsg;//"abc"; rt_kprintf("3 "); /* 分配缓冲区 */ client.buf_size = client.readbuf_size = 1024; client.buf = malloc(client.buf_size); client.readbuf = malloc(client.readbuf_size); if (!(client.buf && client.readbuf)) { LOG_E("no memory for MQTT client buffer!"); return; } rt_kprintf("4 "); /* 设置事件回调函数 */ client.connect_callback = mqtt_connect_callback; client.online_callback = mqtt_online_callback; client.offline_callback = mqtt_offline_callback; /* 设置订阅表和事件回调函数*/ //sprintf(mqtt_subtopic,"device-%s",cpuUuidStringGet()); //rt_kprintf("mqtt:%s",mqtt_subtopic); client.messageHandlers[0].topicFilter = "test"; //订阅主题 client.messageHandlers[0].callback = mqtt_sub_callback; client.messageHandlers[0].qos = QOS2; /* 设置默认的订阅主题*/ client.defaultMessageHandler = mqtt_sub_default_callback; rt_kprintf("5 "); } /* 运行 MQTT 客户端 */ paho_mqtt_start(&client); rt_kprintf("6 "); is_started = 1; } FINSH_FUNCTION_EXPORT(mq_start, startup mqtt client); MSH_CMD_EXPORT(mq_start, startup mqtt client); ```
查看更多
9
个回答
默认排序
按发布时间排序
MurphyZhao
认证专家
2019-10-29
这家伙很懒,什么也没写!
这个跟 cJSON 有关系? 建议 LZ 排除法查找下
ssp97
2019-10-29
这家伙很懒,什么也没写!
>这个跟 cJSON 有关系? > >建议 LZ 排除法查找下 --- 因为我注释掉用到cjson的函数问题就不出现了
MurphyZhao
认证专家
2019-10-29
这家伙很懒,什么也没写!
>因为我注释掉用到cjson的函数问题就不出现了 --- 单独测试 CJSON 部分呢
WKJay
认证专家
2019-10-30
wkjay.com
是不是json数据太大了,而MQTT运行内存太小导致MQTT运行异常,可以适当减小json数据大小进行测试
文武斌
2019-12-03
这家伙很懒,什么也没写!
rt_malloc的问题,申请的内存在用完后释放掉
yuannanzyy
2019-12-03
这家伙很懒,什么也没写!
在这个函数里没有释放内存 char * api_online(char status)
hichard
认证专家
2019-12-04
这家伙很懒,什么也没写!
更新mqtt组件
ren
2020-03-21
这家伙很懒,什么也没写!
请问解决了吗
coulson
2020-04-03
这家伙很懒,什么也没写!
>这个跟 cJSON 有关系? > >建议 LZ 排除法查找下 --- 这个问题我遇到过,因为是循环调用api_online( )这个函数,使用完cJSON创建的root都需要调用cJSON_Delete()来删除,并且使用cJSON_PrintUnformatted() 输出的out 在使用完成之后也需要释放
撰写答案
登录
注册新账号
关注者
0
被浏览
2.1k
关于作者
ssp97
这家伙很懒,什么也没写!
提问
1
回答
1
被采纳
0
关注TA
发私信
相关问题
1
有关动态模块加载的一篇论文
2
最近的调程序总结
3
晕掉了,这么久都不见layer2的踪影啊
4
继续K9ii的历程
5
[GUI相关] FreeType 2
6
[GUI相关]嵌入式系统中文输入法的设计
7
20081101 RT-Thread开发者聚会总结
8
嵌入式系统基础
9
linux2.4.19在at91rm9200 上的寄存器设置
10
[转]基于嵌入式Linux的通用触摸屏校准程序
推荐文章
1
RT-Thread应用项目汇总
2
玩转RT-Thread系列教程
3
国产MCU移植系列教程汇总,欢迎查看!
4
机器人操作系统 (ROS2) 和 RT-Thread 通信
5
五分钟玩转RT-Thread新社区
6
【技术三千问】之《玩转ART-Pi》,看这篇就够了!干货汇总
7
关于STM32H7开发板上使用SDIO接口驱动SD卡挂载文件系统的问题总结
8
STM32的“GPU”——DMA2D实例详解
9
RT-Thread隐藏的宝藏之completion
10
【ART-PI】RT-Thread 开启RTC 与 Alarm组件
最新文章
1
RT-thred的stm32h723对应bsp包CubeMX添加其他外设报错
2
RT-Thread中的time溢出问题,时间戳溢出,解决方法
3
ART-PI使用env驱动ETH网卡,pc和板子可以ping通
4
SystemView线程名字不显示
5
只用网页也能跑RT-Smart 无门槛腾讯Cloud studio + smart-build快速构建
热门标签
RT-Thread Studio
串口
Env
LWIP
SPI
AT
Bootloader
Hardfault
CAN总线
FinSH
ART-Pi
DMA
USB
文件系统
RT-Thread
SCons
RT-Thread Nano
线程
MQTT
STM32
RTC
rt-smart
FAL
I2C_IIC
ESP8266
UART
cubemx
WIZnet_W5500
ota在线升级
PWM
BSP
flash
freemodbus
packages_软件包
潘多拉开发板_Pandora
定时器
ADC
GD32
flashDB
socket
编译报错
中断
Debug
rt_mq_消息队列_msg_queue
keil_MDK
ulog
SFUD
msh
C++_cpp
MicroPython
本月问答贡献
RTT_逍遥
8
个答案
2
次被采纳
三世执戟
7
个答案
1
次被采纳
KunYi
7
个答案
1
次被采纳
winfeng
2
个答案
1
次被采纳
chenyaxing
2
个答案
1
次被采纳
本月文章贡献
catcatbing
2
篇文章
5
次点赞
swet123
1
篇文章
3
次点赞
YZRD
1
篇文章
2
次点赞
Days
1
篇文章
2
次点赞
阳光的掌控者
1
篇文章
1
次点赞
回到
顶部
发布
问题
分享
好友
手机
浏览
扫码手机浏览
投诉
建议
回到
底部