OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 5865|回复: 17

Cjson cJSON_Parse函数返回空

[复制链接]

34

主题

322

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1835
金钱
1835
注册时间
2014-12-4
在线时间
717 小时
发表于 2020-4-8 21:31:52 | 显示全部楼层 |阅读模式
10金钱
最近弄了一个wifi获取天气的程序,使用cjson解析墨迹天气返回的json程序,但是使用 cJSON_Parse()函数将文本转成JSON结构时总是返回空,不知道哪里原因,有遇到过的朋友可以帮忙看看。
获取到的未来6天天气数据
{"code":0,"data":{"city":{"cityId":284975,"counname":"涓浗","ianatimezone":"Asia\/Shanghai","name":"鍘嗗煄鍖?","pname":"灞变笢鐪?","secondaryname":"娴庡崡甯?","timezone":"8"},"forecast":[{"conditionDay":"灏忛洦","conditionIdDay":"7","conditionIdNight":"7","conditionNight":"灏忛洦","humidity":"56","pop":"60","predictDate":"2020-04-08","qpf":"0.7","tempDay":"18","tempNight":"7","updatetime":"2020-04-08 20:07:00","uvi":"4","windDegreesDay":"135","windDegreesNight":"135","windDirDay":"涓滃崡椋?","windDirNight":"涓滃崡椋?","windLevelDay":"3-4","windLevelNight":"3-4"},{"conditionDay":"涓洦","conditionIdDay":"8","conditionIdNight":"7","conditionNight":"灏忛洦","humidity":"72","pop":"80","predictDate":"2020-04-09","qpf":"11.7","tempDay":"11","tempNight":"5","updatetime":"2020-04-08 20:07:00","uvi":"1","windDegreesDay":"45","windDegreesNight":"45","windDirDay":"涓滃寳椋?","windDirNight":"涓滃寳椋?","windLevelDay":"4-5","windLevelNight":"3-4"},{"conditionDay":"闃?","conditionIdDay":"2","conditionIdNight":"31","conditionNight":"澶氫簯","humidity":"67","pop":"60","predictDate":"2020-04-10","qpf":"3.1","tempDay":"13","tempNight":"6","updatetime":"2020-04-08 20:07:00","uvi":"1","windDegreesDay":"45","windDegreesNight":"0","windDirDay":"涓滃寳椋?","windDirNight":"鍖楅","windLevelDay":"3-4","windLevelNight":"3-4"},{"conditionDay":"澶氫簯","conditionIdDay":"1","conditionIdNight":"31","conditionNight":"澶氫簯","humidity":"40","pop":"20","predictDate":"2020-04-11","qpf":"0.0","tempDay":"16","tempNight":"7","updatetime":"2020-04-08 20:07:00","uvi":"9","windDegreesDay":"0","windDegreesNight":"0","windDirDay":"鍖楅","windDirNight":"鍖楅","windLevelDay":"3-4","windLevelNight":"3"},{"conditionDay":"鏅?","conditionIdDay":"0","conditionIdNight":"30","conditionNight":"鏅?","humidity":"30","pop":"20","predictDate":"2020-04-12","qpf":"0.0","tempDay":"19","tempNight":"7","updatetime":"2020-04-08 20:07:00","uvi":"9","windDegreesDay":"0","windDegreesNight":"180","windDirDay":"鍖楅","windDirNight":"鍗楅","windLevelDay":"3-4","windLevelNight":"3"},{"conditionDay":"鏅?","conditionIdDay":"0","conditionIdNight":"30","conditionNight":"鏅?","humidity":"25","pop":"20","predictDate":"2020-04-13","qpf":"0.0","tempDay":"22","tempNight":"11","updatetime":"2020-04-08 20:07:00","uvi":"11","windDegreesDay":"180","windDegreesNight":"180","windDirDay":"鍗楅","windDirNight":"鍗楅","windLevelDay":"3-4","windLevelNight":"4-5"}]},"msg":"success","rc":{"c":0,"p":"success"}}

已经验证这些文本数据转成JSON是对的,但是使用cJSON_Parse()就返回空。校验结果如下:
微信截图_20200408212931.jpg

最佳答案

查看完整内容[请看2#楼]

内存分配的太小了,导致cjson申请内存失败,扩大内存池就可以了
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

34

主题

322

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1835
金钱
1835
注册时间
2014-12-4
在线时间
717 小时
 楼主| 发表于 2020-4-8 21:31:53 | 显示全部楼层
微信截图_20200409202807.png

内存分配的太小了,导致cjson申请内存失败,扩大内存池就可以了  
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165352
金钱
165352
注册时间
2010-12-1
在线时间
2108 小时
发表于 2020-4-9 01:05:19 | 显示全部楼层
帮顶
回复

使用道具 举报

3

主题

16

帖子

0

精华

高级会员

Rank: 4

积分
704
金钱
704
注册时间
2019-7-26
在线时间
93 小时
发表于 2020-4-9 08:37:57 | 显示全部楼层
会不会数据量太大了,弄点小数据试试,看看是哪里的问题
回复

使用道具 举报

34

主题

322

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1835
金钱
1835
注册时间
2014-12-4
在线时间
717 小时
 楼主| 发表于 2020-4-9 12:53:24 | 显示全部楼层
两仪式 发表于 2020-4-9 08:37
会不会数据量太大了,弄点小数据试试,看看是哪里的问题

获取实时天气数据,数据量少可以,感觉像是STM32堆设置小了,晚上回去改大点试试
回复

使用道具 举报

3

主题

1155

帖子

0

精华

论坛元老

Rank: 8Rank: 8

积分
7462
金钱
7462
注册时间
2015-1-15
在线时间
1367 小时
发表于 2020-4-9 13:47:38 | 显示全部楼层
Heap_Size加大解决
一分耕耘一分收获。
回复

使用道具 举报

34

主题

322

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1835
金钱
1835
注册时间
2014-12-4
在线时间
717 小时
 楼主| 发表于 2020-4-9 19:22:11 | 显示全部楼层

微信截图_20200409192058.png    改大试了试还是不行
回复

使用道具 举报

3

主题

1155

帖子

0

精华

论坛元老

Rank: 8Rank: 8

积分
7462
金钱
7462
注册时间
2015-1-15
在线时间
1367 小时
发表于 2020-4-10 08:41:55 | 显示全部楼层
loudianxin 发表于 2020-4-9 20:30
内存分配的太小了,导致cjson申请内存失败,扩大内存池就可以了

看来你不是原生的,用malloc就需要改动HEAD_SIZE就可以了
一分耕耘一分收获。
回复

使用道具 举报

0

主题

8

帖子

0

精华

初级会员

Rank: 2

积分
54
金钱
54
注册时间
2022-12-30
在线时间
7 小时
发表于 2023-4-19 11:15:21 | 显示全部楼层
我在串口发数据给cjson进行打包,打包几次就内存溢出了,HEAD_SIZE调再大也是会返回空,有没有好办法解决,程序中已经添加了释放和删除json数据都不行 1681801098296.jpg
回复

使用道具 举报

34

主题

322

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1835
金钱
1835
注册时间
2014-12-4
在线时间
717 小时
 楼主| 发表于 2023-4-19 16:23:04 | 显示全部楼层
yfhzs 发表于 2023-4-19 11:15
我在串口发数据给cjson进行打包,打包几次就内存溢出了,HEAD_SIZE调再大也是会返回空,有没有好办法解决, ...

https://blog.csdn.net/louyangyan ... 3#comments_25882542

看看这个可以解决吧
回复

使用道具 举报

0

主题

8

帖子

0

精华

初级会员

Rank: 2

积分
54
金钱
54
注册时间
2022-12-30
在线时间
7 小时
发表于 2023-4-20 14:18:43 | 显示全部楼层
loudianxin 发表于 2023-4-19 16:23
https://blog.csdn.net/louyangyang91/article/details/104751693#comments_25882542

看看这个可以解 ...

早上试了一下依然是这个问题
企业微信截图_16819714913192.png
回复

使用道具 举报

3

主题

800

帖子

0

精华

论坛元老

Rank: 8Rank: 8

积分
3775
金钱
3775
注册时间
2017-3-7
在线时间
1645 小时
发表于 2023-4-20 14:32:58 | 显示全部楼层
yfhzs 发表于 2023-4-20 14:18
早上试了一下依然是这个问题

不建议直接使用malloc和free
自己申请栈空间,自行管理内存
回复

使用道具 举报

0

主题

8

帖子

0

精华

初级会员

Rank: 2

积分
54
金钱
54
注册时间
2022-12-30
在线时间
7 小时
发表于 2023-4-20 14:37:42 | 显示全部楼层
a5820736 发表于 2023-4-20 14:32
不建议直接使用malloc和free
自己申请栈空间,自行管理内存

老哥有什么好的解决方法吗?对内存管理不是很熟悉。
回复

使用道具 举报

3

主题

800

帖子

0

精华

论坛元老

Rank: 8Rank: 8

积分
3775
金钱
3775
注册时间
2017-3-7
在线时间
1645 小时
发表于 2023-4-20 14:38:40 | 显示全部楼层
yfhzs 发表于 2023-4-20 14:37
老哥有什么好的解决方法吗?对内存管理不是很熟悉。

简单的就把原子的拿过来,或者把freertos heap4加进去就行了
回复

使用道具 举报

0

主题

8

帖子

0

精华

初级会员

Rank: 2

积分
54
金钱
54
注册时间
2022-12-30
在线时间
7 小时
发表于 2023-4-20 14:44:49 | 显示全部楼层
本帖最后由 yfhzs 于 2023-4-20 14:47 编辑
a5820736 发表于 2023-4-20 14:38
简单的就把原子的拿过来,或者把freertos heap4加进去就行了

我用的就是原子的myfree
回复

使用道具 举报

3

主题

800

帖子

0

精华

论坛元老

Rank: 8Rank: 8

积分
3775
金钱
3775
注册时间
2017-3-7
在线时间
1645 小时
发表于 2023-4-20 14:51:07 | 显示全部楼层
yfhzs 发表于 2023-4-20 14:44
我用的就是原子的myfree

。。。那试试freertos的,其实没mmu的芯片真不适合动态内存,json这种文件协议不建议底层解析传输
回复

使用道具 举报

34

主题

322

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1835
金钱
1835
注册时间
2014-12-4
在线时间
717 小时
 楼主| 发表于 2023-4-21 15:58:43 | 显示全部楼层
yfhzs 发表于 2023-4-20 14:18
早上试了一下依然是这个问题

监测一下分配的内存指针和释放的内存指针一样吧  
回复

使用道具 举报

34

主题

322

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1835
金钱
1835
注册时间
2014-12-4
在线时间
717 小时
 楼主| 发表于 2023-4-21 16:13:16 | 显示全部楼层
yfhzs 发表于 2023-4-20 14:18
早上试了一下依然是这个问题

微信截图_20230421161215.png 这个地方对吗?
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2024-11-24 11:31

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

快速回复 返回顶部 返回列表