用C语言获取JSON中的数据的方法是使用 CJSON。
以下简单介绍用CJSON的思路及实现:
1)创建json,从json中获取数据。
#nclude <stdio.h>
#include "cJSON.h"
char * makeJson()
{
cJSON * pJsonRoot = NULL
pJsonRoot = cJSON_CreateObject()
if(NULL == pJsonRoot)
{
//error happend here
return NULL
}
cJSON_AddStringToObject(pJsonRoot, "hello", "hello world")
cJSON_AddNumberToObject(pJsonRoot, "number", 10010)
cJSON_AddBoolToObject(pJsonRoot, "bool", 1)
cJSON * pSubJson = NULL
pSubJson = cJSON_CreateObject()
if(NULL == pSubJson)
{
// create object faild, exit
cJSON_Delete(pJsonRoot)
return NULL
}
cJSON_AddStringToObject(pSubJson, "subjsonobj", "a sub json string")
cJSON_AddItemToObject(pJsonRoot, "subobj", pSubJson)
char * p = cJSON_Print(pJsonRoot)
// else use :
// char * p = cJSON_PrintUnformatted(pJsonRoot)
if(NULL == p)
{
//convert json list to string faild, exit
//because sub json pSubJson han been add to pJsonRoot, so just delete pJsonRoot, if you also delete pSubJson, it will coredump, and error is : double free
cJSON_Delete(pJsonRoot)
return NULL
}
//free(p)
cJSON_Delete(pJsonRoot)
return p
}
void parseJson(char * pMsg)
{
if(NULL == pMsg)
{
return
}
cJSON * pJson = cJSON_Parse(pMsg);
if(NULL == pJson)
{
// parse faild, return
return
}
// get string from json
cJSON * pSub = cJSON_GetObjectItem(pJson, "hello")
if(NULL == pSub)
{
//get object named "hello" faild
}
printf("obj_1 : %s\n", pSub->valuestring)
// get number from json
pSub = cJSON_GetObjectItem(pJson, "number")
if(NULL == pSub)
{
//get number from json faild
}
printf("obj_2 : %d\n", pSub->valueint)
// get bool from json
pSub = cJSON_GetObjectItem(pJson, "bool")
if(NULL == pSub)
{
// get bool from json faild
}
printf("obj_3 : %d\n", pSub->valueint)
// get sub object
pSub = cJSON_GetObjectItem(pJson, "subobj")
if(NULL == pSub)
{
// get sub object faild
}
cJSON * pSubSub = cJSON_GetObjectItem(pSub, "subjsonobj")
if(NULL == pSubSub)
{
// get object from subject object faild
}
printf("sub_obj_1 : %s\n", pSubSub->valuestring)
cJSON_Delete(pJson)
}
int main()
{
char * p = makeJson()
if(NULL == p)
{
return 0
}
printf("%s\n", p)
parseJson(p)
free(p)//这里不要忘记释放内存,cJSON_Print()函数或者cJSON_PrintUnformatted()产生的内存,使用free(char *)进行释放
return 0
}
2)创建json数组和解析json数组
//创建数组,数组值是另一个JSON的item,这里使用数字作为演示
char * makeArray(int iSize)
{
cJSON * root = cJSON_CreateArray()
if(NULL == root)
{
printf("create json array faild\n")
return NULL
}
int i = 0
for(i = 0i <iSizei++)
{
cJSON_AddNumberToObject(root, "hehe", i)
}
char * out = cJSON_Print(root)
cJSON_Delete(root)
return out
}
//解析刚刚的CJSON数组
void parseArray(char * pJson)
{
if(NULL == pJson)
{
return
}
cJSON * root = NULL
if((root = cJSON_Parse(pJson)) == NULL)
{
return
}
int iSize = cJSON_GetArraySize(root)
for(int iCnt = 0iCnt <iSizeiCnt++)
{
cJSON * pSub = cJSON_GetArrayItem(root, iCnt)
if(NULL == pSub)
{
continue
}
int iValue = pSub->valueint
printf("value[%2d] : [%d]\n", iCnt, iValue)
}
cJSON_Delete(root)
return
}
有两种方法:
一是标准的输出输入方式 比如新建一个磁盘文件c:\a.txt, 将键盘输入的一字符串写到文件中:
FILE *ft
char str[50]
ft=fopen("c:\\a.txt","w+")
printf("输入一个字符串:")
scanf("%s",str)
fputs(str,ft)
fclose(ft)
//重新打开这个文件并读出字符串,显示在屏幕上 ft=fopen("c:\\a.txt","rt")
fgets(str,50,ft)
fclose(ft)printf("%s",str)
二是低级输入输出方式 仍如上例:
int hdchar str[50]printf("输入一个字符串:")
scanf("%s",str)
hd=open("c:\\a.txt",O_CREAT|O_TEXT|O_WRONLY)
write(hd,str,strlen(str))
close(hd)//重新打开这个文件并读出字符串,显示在屏幕上。
hd=open("c:\\a.txt",O_TEXT|O_RDONLY)read(hd,str,50)
close(hd)printf("%s",str)。
代码如下:
local cjson = require("cjson")
--lua对象到字符串
local obj = {
id = 1,
name = "zhangsan",
age = nil,
is_male = false,
hobby = {"film", "music", "read"}
}
local str = cjson.encode(obj)
ngx.say(str, "<br/>")
--字符串到lua对象
str = '{"hobby":["film","music","read"],"is_male":false,"name":"zhangsan","id":1,"age":null}'
local obj = cjson.decode(str)
ngx.say(obj.age, "<br/>")
ngx.say(obj.age == nil, "<br/>")
ngx.say(obj.age == cjson.null, "<br/>")
ngx.say(obj.hobby[1], "<br/>")
--循环引用
obj = {
id = 1
}
obj.obj = obj
-- Cannot serialise, excessive nesting
--ngx.say(cjson.encode(obj), "<br/>")
local cjson_safe = require("cjson.safe")
--nil
ngx.say(cjson_safe.encode(obj), "<br/>")
null将会转换为cjson.null;循环引用会抛出异常Cannot serialise, excessive nesting,默认解析嵌套深度是1000,可以通过cjson.encode_max_depth()设置深度提高性能;使用cjson.safe不会抛出异常而是返回nil。
这个明显是WinForm的吧。 1、新建数据库 USE [master] GO /****** Object: Database [数据库名] Script Date: 09/12/2014 16:56:48 ******/ CREATE DATABASE [数据库名] ON PRIMARY ( NAME = N'数据库名', FILENAME = N'D:\Program Files\Micros...欢迎分享,转载请注明来源:内存溢出
评论列表(0条)