您的位置:首页 > Web前端 > JavaScript

【RapidJson】Rapidjson解析

2016-01-06 14:13 579 查看
Json 是一种轻量级数据交换格式,具有易于人阅读和编写,同时也易于机器解析和生成。相较于XML,json更小、读写更快、更易解析。另一方面,Rapidjson作为json的升级版,在效率方面,具有更好的优势。

Json语法规则

1. 数据在名称/值对中

Json数据的书写格式: 名称/值对。

名称/值对包括字段名称(在双引号中),后面跟一个冒号,然后就是值:

例如:

“subject” : ”English”

Json值可以是:数字(整数或浮点数)、字符串(在双引号中)、逻辑值(true或false)、数组(在方括号中)、对象(在花括号中)、null。

Json对象中可以包含多个名称/值对:

例如:

{“subject” : ”English”, “subject” : ”Math”}

Json数组可以包含对象:

例如:

{“student”:[

{“subject” : ”English”, “subject” : ”Math”},

{“subject” : ”Yuwen”, “subject” : ”Music”},

]

}

2. 数据有逗号隔开

这里要注意的是最后一个数据不要加逗号,

3. 花括号用来保存对象

4. 方括号用来保存数组

Rapdijson解析

Json本身是JavaScript对象表示法(JavaScriptOjbect Notation),在javascript层面很容易解析。对于c++,必须导入相关库文件。Cocos2dx从2.1版本后,引入了rapidjson库,因此这里是RapidJson解析。后面讲到的内容也是基于cocos2dx引擎(这里版本为:cocos2d-x-3.2rc0)

在json解析之前,要先了解json几个相关概念:

Value:value其实就是var,对于value可以理解为int,也是理解为string,或者是bool型变量等其他数据类型。对于定义Value value,只是一个定义,还没有决定其数据类型,如果明确value的值,则相应确定其数据类型了。

Json数据类型是一个map,表示为key-value形式,对于Value转换为基础数据类型有以下几种方法:

vall.SetArray() vall.SetArrayRaw() vall.SetBool() vall.SetDouble() vall.SetInt()

vall.SetNull() vall.SetObject() vall.SetString() vall.SetStringRaw() vall.SetUint();

vall.SetUint64()

同时,对于value的数据类型,是可以重复设置。

Write:将Value数据编码成json合适数据格式;

Reader:与Writer相反,是将json格式数据解析成一个Value值。

Json::Readerreader;

示例:

解析一个JSON字符串至一个document (DOM),对DOM作出简单修改,最终把DOM转换(stringify)至JSON字符串。

// JSON simple example
// 包含了Json和string之间互相转换以及中间对dom的修改数据

#include "rapidjson/document.h"
#include "rapidjson/writer.h"
#include "rapidjson/stringbuffer.h"
#include <iostream>

using namespace rapidjson;

int main() {
    // 1. Parse a JSON string into DOM.
<span style="white-space:pre">	</span>//这里面曾经研究过两个知识点:一个是const的修饰位置,二是指向的是char,结果可以输出的是字符串
<span style="white-space:pre">	</span>//疑惑点:字符串里面为什么会有那么多的反斜杠,难道是转义字符的原因
    const char* json = "{\"project\":\"rapidjson\",\"stars\":10}";
    Document d;
    d.Parse(json);

    // 2. Modify it by DOM.
<span style="white-space:pre">	</span>//Value:value其实就是var,对于value可以理解为int,也是理解为string,或者是bool型变量等其他数据类型。对于定义Value value,只是一个定义,还没有决定其数据类型,如果明确value的值,则相应确定其数据类型了。
   //这里只是一个引用,注意文档树的查找方式-->(d["stars"])
<span style="white-space:pre">	</span>Value& s = d["stars"];
<span style="white-space:pre">	</span>//这里对于具体类型数据都有setvalue和getvalue接口
    s.SetInt(s.GetInt() + 1);

    // 3. Stringify the DOM
    StringBuffer buffer;
    Writer<StringBuffer> writer(buffer);
    d.Accept(writer);

    // Output {"project":"rapidjson","stars":11}
    std::cout << buffer.GetString() << std::endl;
    return 0;
}




stringify含义解释:JSON对象和字符串之间的相互转换

比如我有两个变量,我要将a转换成字符串,将b转换成JSON对象:
var a={"name":"tom","sex":"男","age":"24"};
var b='{"name":"Mike","sex":"女","age":"29"}';


在Firefox,chrome,opera,safari,ie9,ie8等高级浏览器直接可以用JSON对象的stringify()和parse()方法。

JSON.stringify(obj)将JSON转为字符串。

JSON.parse(string)将字符串转为JSON格式;

上面的转换可以这么写:
var a={"name":"tom","sex":"男","age":"24"};

var b='{"name":"Mike","sex":"女","age":"29"}';

var aToStr=JSON.stringify(a);

var bToObj=JSON.parse(b);

alert(typeof(aToStr));  //string

alert(typeof(bToObj));//object


ie8(兼容模式),ie7和ie6没有JSON对象,不过http://www.json.org/提供了一个json.js,这样ie8(兼容模式),ie7和ie6就可以支持JSON对象以及其stringify()和parse()方法;你可以在https://github.com/douglascrockford/JSON-js上获取到这个js,一般现在用json2.js。

ie8(兼容模式),ie7和ie6可以使用eval()将字符串转为JSON对象,
var c='{"name":"Mike","sex":"女","age":"29"}';
var cToObj=eval("("+c+")");
alert(typeof(cToObj));


jQuery中也有将字符串转为JSON格式的方法jQuery.parseJSON(
json ),接受一个标准格式的 JSON 字符串,并返回解析后的 JavaScript (JSON)对象。当然如果有兴趣可以自己封装一个jQuery扩展,jQuery.stringifyJSON(obj)将JSON转为字符串。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: