2、Writer
如上说了 Json::Value 的使用方式,如今到了该查看刚才赋值内容的时候了,查看 json 内容,使用Writer 类就可以。
Jsoncpp 的 Json::Writer 类是一个纯虚类,并不能直接使用。在此我们使用 Json::Writer 的子类:Json::FastWriter、Json::StyledWriter、Json::StyledStreamWriter。
顾名思义,用 Json::FastWriter 来处理 json 应该是最快的,以下我们来试试。
Json::FastWriter fast_writer;
std::cout << fast_writer.write(root) << std::endl;
输出结果为:
{"key_array":["array_string",1234],"key_boolean":false,"key_double":12.3450,"key_number":12345,"key_object":{"age":26,"name":"huchao"},"key_string":"value_string"}
再次顾名思义,用 Json::StyledWriter 是格式化后的 json,以下我们来看看 Json::StyledWriter 是如何格式化的。
Json::StyledWriter styled_writer;
std::cout << styled_writer.write(root) << std::endl;
输出结果为:
{ "key_array" : [ "array_string", 1234 ], "key_boolean" : false, "key_double" : 12.3450, "key_number" : 12345, "key_object" : { "age" : 26, "name" : "huchao" }, "key_string" : "value_string" } |
3、Reader
Json::Reader 是用于读取的,说的确切点,是用于将字符串转换为 Json::Value 对象的,以下我们来看个简单的样例。
Json::Reader reader;
Json::Value json_object;
const char* json_document = "{/"age/" : 26,/"name/" : /"huchao/"}";
if (!reader.parse(json_document, json_object))
return 0;
std::cout << json_object["name"] << std::endl;
std::cout << json_object["age"] << std::endl;
输出结果为:
"huchao"
26
可见,上述代码已经解析出了 json 字符串。
4、以下这段代码演示了怎么使用Json中的值
std::string test = "{\"test\":5,\ \"Value\":{\"version\":\"this is version\"}}"; Json::Reader reader; Json::Value value; if(reader.parse(test,value)) { int i = 0; bool isNull = value["test"].isNull(); if(!isNull) i = value["test"].asInt(); if(!value["Value"]["version"].isNull()) { std::string str = value["Value"]["version"].asString(); } Json::Value val1= value["OtherKey"]; if(!val1.isNull()) { i = val1.asInt(); } } |
--------------------------------------
[1]:使用第三方源代码最简单的方法是直接将文件增加project,但这样不利于源代码、软件产品管理,对于一般软件开发来说,不建议使用。
[2]:假设真须要编译成动态链接库、静态导入库的话,能够使用 VS 新建一个project属性,然后在Project --> Properties中进行对应的设置就可以。