JSON_笔记

本文介绍了JSON的基本概念及JSONRPC远程调用服务,并详细展示了如何利用C语言进行JSON数据包的解析与创建过程,包括数据结构定义、解析函数调用及内存管理等关键步骤。

JSON :JavaScript Object Notation

JSON RPC: JSON Remote Protocol Call 是一种基于JSON协议的远程调用服务,多平台通用,可使用HTTP或其他传输协议。

相比XML RPC ,XML体积大,格式复杂,解析XML比较复杂。


Some JSON:
{
    "name": "Jack (\"Bee\") Nimble", 
    "format": {
        "type":       "rect", 
        "width":      1920, 
        "height":     1080, 
        "interlace":  false, 
        "frame rate": 24
    }
}


CJSON结构体

typedef struct cJSON {
	struct cJSON *next,*prev;
	struct cJSON *child;

	int type;

	char *valuestring;
	int valueint;
	double valuedouble;

	char *string;
} cJSON;



cJSON结构体是一个双向链表,可通过child指针访问下一层

type表示数据项(键)类型,先判断type类型,在分别从对应的valuestring valueint valuedouble中提取数据

string表示节点名称



JSON数据包:

char text[] = "{\"timestamp\":\"2013-11-19T08:50:11\",\"value\":1}"; 

解析JSON:

cJSON *root = cJSON_Parse(my_json_string);//解析JSON数据包,按照CJSON结构体序列号数据包,该函数会调用malloc
cJSON *format = cJSON_GetObjectItem(root,"format");//查找某个节点
if( format ->type <span style="font-family: Arial, Helvetica, sans-serif;">== cJSON_Number ) </span>
{
	int framerate = cJSON_GetObjectItem(format,"frame rate")->valueint;//获取节点的值
}
cJSON_Delete(json);//释放空间 
注意:cJSON_Parse函数会调用malloc开辟内存空间,需要在结束后释放空间


创建JSON:

 cJSON *root = cJSON_CreateObject();  <span style="font-family: Arial, Helvetica, sans-serif;">// 创建JSON Object  </span>

cJSON_AddNumberToObject(root,"value",123.4);  <span style="font-family: Arial, Helvetica, sans-serif;">// 加入节点(键值对),节点名称为value,节点值为123.4  </span>

// 打印JSON数据包  
char *out = cJSON_Print(root);  
printf("%s\n",out);  

// 释放内存  
cJSON_Delete(root);  
free(out);  


简单用C语言合成JSON字符串:

//将数据合成为JSON格式数据
sprintf(meassage,"{\"temperature\":%.1f,\"humidity\":%.1f,\"light\":%.1f,\"pressure\":%.1f}",temperature,humidity,light,pressure);








json_array_elements()和json_array_elements_text()是用于展开JSON数组的函数。json_array_elements()函数将展开JSON数组中的每个元素,并返回一个包含这些元素的表。json_array_elements_text()函数与之类似,但是返回的是每个元素的文本值。这两个函数可以帮助我们在SQL中处理JSON数据。 另外,json_populate_record(base anyelement,from_json json)是一个函数,它可以将一个JSON对象的值填充到指定的表中的对应列中。这个函数通常与json_array_elements()函数一起使用,以便处理复杂的JSON数据结构并将其插入到表中。 综上所述,json_array_elements()和json_array_elements_text()是用于展开JSON数组的函数,而json_populate_record()是用于将JSON值填充到表中的函数。它们都是在处理JSON数据时非常有用的函数。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [PG常用操作笔记(一)](https://blog.youkuaiyun.com/wyj180/article/details/120632916)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *2* [金仓数据库 KingbaseES SQL 语言参考手册 (8. 函数(六))](https://blog.youkuaiyun.com/arthemis_14/article/details/125928310)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值