当前位置: 首页 > news >正文

cJSON

cJSON 是一个用 C 语言编写的轻量级 JSON 解析库,旨在提供简单、高效的方式来处理 JSON 数据。它适用于需要解析或生成 JSON 数据的各种应用场景,尤其是资源受限的嵌入式系统或对性能有较高要求的项目。

https://github.com/DaveGamble/cJSON/releases 

typedef struct cJSON
{/* next/prev 允许您遍历数组/对象链。也可以使用 GetArraySize/GetArrayItem/GetObjectItem */struct cJSON *next;struct cJSON *prev;/* 数组或对象项将有一个 child 指针,指向数组/对象中项目的链 */struct cJSON *child;/* 项目的类型,如上所述 */int type;/* 如果 type == cJSON_String 或 type == cJSON_Raw,则为项目的字符串值 */char *valuestring;/* 写入 valueint 已被弃用,请使用 cJSON_SetNumberValue 代替 */int valueint;/* 如果 type == cJSON_Number,则为项目的数字值 */double valuedouble;/* 如果该项目是对象的孩子,或者在对象子项列表中,则为项目的名称字符串 */char *string;
} cJSON;

 cJSON 库的常用函数接口的表格形式,包含每个函数的简要说明和示例代码。这些函数涵盖了创建、解析、修改和输出 JSON 数据的主要操作。

函数接口功能说明示例代码
解析 JSON
cJSON *cJSON_Parse(const char *value)解析一个 JSON 字符串并返回一个指向 cJSON 结构体的指针。c<br>cJSON *json = cJSON_Parse("{\"name\": \"Alice\"}");<br>if (json == NULL) {<br> // 处理错误<br>}<br>
void cJSON_Delete(cJSON *c)释放由 cJSON_Parse 或其他创建函数分配的内存。c<br>cJSON_Delete(json);<br>
创建 JSON
cJSON *cJSON_CreateNull(void)创建一个表示 null 的 JSON 节点。c<br>cJSON *nullItem = cJSON_CreateNull();<br>
cJSON *cJSON_CreateBool(cJSON_bool boolean)创建一个布尔值的 JSON 节点。c<br>cJSON *boolItem = cJSON_CreateBool(1); // true<br>
cJSON *cJSON_CreateNumber(double num)创建一个数字值的 JSON 节点。c<br>cJSON *numberItem = cJSON_CreateNumber(123.45);<br>
cJSON *cJSON_CreateString(const char *string)创建一个字符串值的 JSON 节点。c<br>cJSON *stringItem = cJSON_CreateString("Hello, World!");<br>
cJSON *cJSON_CreateArray(void)创建一个空的 JSON 数组。c<br>cJSON *array = cJSON_CreateArray();<br>
cJSON *cJSON_CreateObject(void)创建一个空的 JSON 对象。c<br>cJSON *object = cJSON_CreateObject();<br>
修改 JSON
void cJSON_AddItemToArray(cJSON *array, cJSON *item)向 JSON 数组中添加一个项目。c<br>cJSON_AddItemToArray(array, cJSON_CreateString("Item1"));<br>
void cJSON_AddItemToObject(cJSON *object, const char *string, cJSON *item)向 JSON 对象中添加一个键值对。c<br>cJSON_AddItemToObject(object, "key", cJSON_CreateNumber(1));<br>
void cJSON_ReplaceItemInObject(cJSON *object, const char *string, cJSON *newitem)替换 JSON 对象中指定键的值。c<br>cJSON_ReplaceItemInObject(object, "key", cJSON_CreateNumber(2));<br>
查询 JSON
cJSON *cJSON_GetObjectItemCaseSensitive(cJSON *object, const char *string)获取 JSON 对象中指定键的项,区分大小写。c<br>cJSON *item = cJSON_GetObjectItemCaseSensitive(object, "key");<br>
cJSON_bool cJSON_HasObjectItem(cJSON *object, const char *string)检查 JSON 对象中是否存在指定键。c<br>if (cJSON_HasObjectItem(object, "key")) {<br> // 处理存在<br>}<br>
输出 JSON
char *cJSON_Print(cJSON *item)将 cJSON 结构体转换为格式化的 JSON 字符串。c<br>char *json_str = cJSON_Print(json);<br>printf("%s\n", json_str);<br>
char *cJSON_PrintUnformatted(cJSON *item)将 cJSON 结构体转换为无格式的 JSON 字符串(不带空格和换行)。c<br>char *json_str = cJSON_PrintUnformatted(json);<br>printf("%s\n", json_str);<br>
其他常用函数
cJSON_bool cJSON_IsNull(cJSON *item)检查一个 cJSON 项是否为 nullc<br>if (cJSON_IsNull(item)) {<br> // 处理 null<br>}<br>
cJSON_bool cJSON_IsBool(cJSON *item)检查一个 cJSON 项是否为布尔值。c<br>if (cJSON_IsBool(item)) {<br> // 处理布尔值<br>}<br>
cJSON_bool cJSON_IsNumber(cJSON *item)检查一个 cJSON 项是否为数字。c<br>if (cJSON_IsNumber(item)) {<br> // 处理数字<br>}<br>
cJSON_bool cJSON_IsString(cJSON *item)检查一个 cJSON 项是否为字符串。c<br>if (cJSON_IsString(item)) {<br> // 处理字符串<br>}<br>

示例代码

一个综合示例,展示了如何使用上述函数来创建、解析、修改和输出 JSON 数据:

#include <stdio.h>
#include <cjson/cJSON.h>int main()
{// 创建 JSON 对象cJSON *root = cJSON_CreateObject();cJSON_AddItemToObject(root, "name", cJSON_CreateString("Alice"));cJSON_AddItemToObject(root, "age", cJSON_CreateNumber(30));cJSON_AddItemToObject(root, "isStudent", cJSON_CreateBool(0));// 创建 JSON 数组并添加到对象中cJSON *courses = cJSON_CreateArray();cJSON_AddItemToArray(courses, cJSON_CreateString("Math"));cJSON_AddItemToArray(courses, cJSON_CreateString("Science"));cJSON_AddItemToArray(courses, cJSON_CreateString("History"));cJSON_AddItemToObject(root, "courses", courses);// 输出 JSON 字符串char *json_str = cJSON_Print(root);printf("Original JSON:\n%s\n", json_str);// 解析 JSON 字符串cJSON *parsed = cJSON_Parse(json_str);if (parsed == NULL){printf("Error parsing JSON\n");cJSON_Delete(root);free(json_str);return 1;}// 修改 JSON 数据cJSON_ReplaceItemInObject(parsed, "age", cJSON_CreateNumber(31));cJSON_ReplaceItemInObject(parsed, "isStudent", cJSON_CreateBool(1));// 添加新的键值对cJSON_AddItemToObject(parsed, "email", cJSON_CreateString("alice@example.com"));// 输出修改后的 JSON 字符串char *modified_json_str = cJSON_Print(parsed);printf("Modified JSON:\n%s\n", modified_json_str);// 释放内存cJSON_Delete(root);cJSON_Delete(parsed);free(json_str);free(modified_json_str);return 0;
}

输出结果

Original JSON:
{"name": "Alice","age": 30,"isStudent": false,"courses": ["Math","Science","History"]
}
Modified JSON:
{"name": "Alice","age": 31,"isStudent": true,"courses": ["Math","Science","History"],"email": "alice@example.com"
}

 

相关文章:

  • Linux中进程的属性:状态
  • 18487.1-2015-解读笔记五-交流充电之停止充电
  • AI与Web3.0:技术融合
  • C#语言实现PDF转Excel
  • 26、C# 中是否可以继承String类?为什么?
  • GD32F407单片机开发入门(六)定时器TIMER详解及实战含源码
  • Redis 服务自动开启、设置密码和闪退问题
  • .NET、java、python语言连接SAP系统的方法
  • 深入探究Python中`__init__.py`文件的奥秘
  • 【AI应用】免费代码仓构建定制版本的ComfyUI应用镜像
  • 声纹振动传感器在电力监测领域的应用
  • 数据一致性问题剖析与实践(三)——分布式事务的一致性问题
  • Spring Boot中的监视器:Actuator的原理、功能与应用
  • JavaScript 防抖和节流
  • JavaFX 第一篇 Hello World
  • 在线测试来料公差
  • 【开源】STM32HAL库移植Arduino OneWire库驱动DS18B20和MAX31850
  • 香港科技大学广州|先进材料学域博士招生宣讲会—南开大学专场
  • OpenCV 图形API(54)颜色空间转换-----将图像从 RGB 色彩空间转换到 HSV色彩空间RGB2HSV()
  • day001
  • 外交部回应美财长涉中国发展经济模式言论:损害各国人民共同利益的是美方
  • 建投读书会·东西汇流|东西方戏剧在上海的相逢、交锋与融合
  • 《亡命驾驶》:一场对于男子气概的终极幻想
  • 上海车展上的双向奔赴:跨国车企融入中国创新,联手“在中国,为全球”
  • 俄总理:2024年俄罗斯GDP增长4.3%
  • 金湘军辞去山西省省长职务