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中进行对应的设置可以。