Toggle navigation
首页
问答
文章
积分商城
专家
专区
更多专区...
文档中心
返回主站
搜索
提问
会员
中心
登录
注册
cjson
json
更低内存占用的c语言通用Json库 - RyanJson
发布于 2023-08-23 16:08:03 浏览:1924
订阅该版
[tocm] ### *希望有兴趣的大佬多试试,找找bug、提提意见*😀 ### *详细信息可以访问文末的 RyanDocs 网站查看* # RyanJson **github链接:https://github.com/Ryan-CW-Code/RyanJson** ***一个针对资源受限的嵌入式设备优化的c语言Json库,内存占用极小的通用Json库,简洁高效!*** *初衷:项目进行重构json结构变复杂了很多,cJSON内存占用太高,已经满足不了需求。* ## 1、介绍 RyanJson是一个小巧的c语言json解析器,包含json文本文件解析 / 生成,**专门针对内存占用进行优化**,相比cJSON内存占用减少30% - 60%,运行速度和cJSON差不多。 - **低内存占用**:使用动态扩展技术,在32位系统下,一个基础json节点仅占用8字节。 - **开发人员友好**:仅有一个c文件和头文件轻松集成,hook函数方便自定义内存钩子。类cJSON的api,迁移成本低。 - **严格但不严苛**:符合 RFC 8295 大部分JSON标准,支持无限的json嵌套级别(需注意堆栈空间)、灵活的配置修改项 - **可扩展性**:允许注释(需调用mini函数清除注释后再解析)、尾随逗号等无效字符(parse时可配置是否允许)等 ## 2、设计 **RyanJson设计时大量借鉴了 [json](https://api.gitee.com/Lamdonn/json) 和 [cJSON](https://github.com/DaveGamble/cJSON) ! 是从 [json](https://api.gitee.com/Lamdonn/json) 的基础上修改来的** json语法是**JavaScript**对象语法的子集,可通过下面两个连接学习json语法。 [JSON规范](https://www.json.org/json-en.html) [Parsing JSON is a Minefield 建议看看](https://seriot.ch/projects/parsing_json.html) 在json语法中,数据以键值对的形式存储(数组没有key) 在RyanJson解析器中,**使用结构体来表示一个键值对,是存储的最小单元**,结构如下: ```c struct RyanJsonNode { uint32_t info; // 包含类型,key等标志 struct RyanJsonNode *next; // 单链表node节点 // [char *key] 有key的json节点, 会动态创建指针 // 有value值的节点, 会动态创建指针 // [int32_t value / double value / char* value / RyanJson_t item] }; typedef struct RyanJsonNode *RyanJson_t; ``` **此结构体包含两个固定成员 info 和 next;** **info**:为当前节点的配置信息用来表示 节点数据类型 和 flag标志位。 ``` bits low --> high --------------------------------------------------------------------- | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | NA | NA | ....... --------------------------------------------------------------------- \______________________________/ | | | low 8bits | | | | | | | V | | | RyanJsonTypeUnknow (bit0) | | | RyanJsonTypeNull (bit1) | | | RyanJsonTypeBool (bit2) | | +----> RyanJsonWithKeyFlag (1 << 10) RyanJsonTypeNumber (bit3) | | RyanJsonTypeString (bit4) | +--------> RyanJsonValueNumberIntFlag (1 << 9) RyanJsonTypeArray (bit5) | RyanJsonTypeObject (bit6) +------------> RyanJsonValueBoolTrueFlag (1 << 8) spare (bit7) ``` **next**:指针指向链表下一个节点 ``` { "name": "RyanJson", next ( "version": "xxx", next ( "repository": "https://github.com/Ryan-CW-Code/RyanJson", next ( "keywords": ["json", "streamlined", "parser"], next ( \__item__/ \__next__/ \__next__/ "others": { ... } } ``` **此结构体还包括两个可能动态创建的成员 key 和 value;** **key**:存储键值对的 key 信息,当存在key时会在申请RyanJsonNode内存时,动态添加。 **value**:存储键值对的 value 信息,会根据不同节点类型创建不同的value值。会在申请RyanJsonNode内存时,动态添加。 ## 3、测试 测试代码可在本项目根目录查看。 #### 性能测试 RyanDocs文档中心,有基于 yyjson_benchmark 的测试结果 #### 内存占用测试 ![screenshot_image.png](https://oss-club.rt-thread.org/uploads/20230823/cfdf5ce2d4d8ce01dd58621c4a701957.png) #### RFC 8295 标准测试,大部分嵌入式场景不会出现复杂的特殊json结构 ***RyanJson和cJSON都不适合处理复杂的UTF-16字符集,如果项目需要兼容Unicode字符集,可以考虑yyjson / json-c*** ![screenshot_image.png](https://oss-club.rt-thread.org/uploads/20230823/cf3c78ccd6c724051d4de7c64fdc2de8.png) ## 4、局限性 - 使用int / double表示json中的number类型,**精度有所丢失**。建议64位的number类型最好用string字符串表示。 - **对象中允许有重复的key**,RyanJson库采用单向链表,会访问到第一个对象。 ## 5、文档 文档可在 [Ryan文档中心](https://ryan-cw-code.github.io/RyanDocs/)获取 ## 6、联系 Email:1831931681@qq.com wx:17513216936
15
条评论
默认排序
按发布时间排序
登录
注册新账号
关于作者
Ryan_CW
这家伙很懒,什么也没写!
文章
9
回答
74
被采纳
15
关注TA
发私信
相关文章
1
pandora开发板使用cjson,内存不足。
2
cjson 安装后编译 出现报错
3
cjson软件包编译出现警告
4
阿里云控制台发送到板子上的数据存放在哪里?
5
rt_cjson_tool 创建json字符串问题?
6
哪位大神用webnet向网页直接返回json字符串?
7
rtthread最新版的cjson软件包打印构建好的数据是NULL?
8
mqtt的cjson中如何获取多个键值对?
9
cJSON、kawaii-mqtt结合使用示例
10
cJSON解析内存占用极高,有没有解决办法?
推荐文章
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组件
热门标签
RT-Thread Studio
串口
Env
LWIP
SPI
AT
Bootloader
Hardfault
CAN总线
FinSH
ART-Pi
DMA
USB
文件系统
RT-Thread
SCons
RT-Thread Nano
线程
MQTT
STM32
RTC
FAL
rt-smart
I2C_IIC
ESP8266
UART
WIZnet_W5500
ota在线升级
cubemx
PWM
flash
freemodbus
BSP
packages_软件包
潘多拉开发板_Pandora
定时器
ADC
flashDB
GD32
socket
编译报错
中断
Debug
rt_mq_消息队列_msg_queue
keil_MDK
SFUD
msh
ulog
C++_cpp
MicroPython
本月问答贡献
出出啊
1518
个答案
343
次被采纳
小小李sunny
1444
个答案
290
次被采纳
张世争
813
个答案
177
次被采纳
crystal266
549
个答案
161
次被采纳
whj467467222
1222
个答案
149
次被采纳
本月文章贡献
出出啊
1
篇文章
3
次点赞
小小李sunny
1
篇文章
1
次点赞
张世争
1
篇文章
3
次点赞
crystal266
2
篇文章
2
次点赞
whj467467222
2
篇文章
2
次点赞
回到
顶部
发布
问题
投诉
建议
回到
底部