Jsoncpp-所见即所得使用范例

29次阅读

共计 1374 个字符,预计需要花费 4 分钟才能阅读完成。

jsoncpp 版本: jsoncpp-1.8.4

基本操作

#include <json/json.h>

int main() {
  Json::Value root;
  
  root["key1"] = 1;
  root["key2"] = "good";
  root["indent"]["length"] = 2;
  root["indent"]["use_space"] = true;

  Json::Value v(Json::arrayValue);
  v[0] = "clojure";
  v[1] = "json";
  v[2] = "xml";
  root["key3"] = v;
  return 0;
}

遍历与类型

  for (auto i = root.begin(); i != root.end(); i++) {
    Json::Value& obj = *i;
    const std::string name = i.name();
    std::cout << name << "-" << i.key() << ":" << obj.isArray() << "\n";
  }

读入

  Json::Value root;
  std::ifstream infile;
  infile.open("your.json", std::ios::in);
  try {infile >> root;} catch (std::exception& e) {root = Json::objectValue;}
  infile.close();

这里用的是文件的读入流, 也可以是文本的stringstream

写出

  std::ofstream of;
  of.open("your.json", std::ios::out);
  of << root << std::endl;
  of.flush();
  of.close();

格式化输出

默认输出的 json 缩进是\t, 如果要改成 2 个空格:

  Json::StreamWriterBuilder builder;
  builder["indentation"] = " ";
  builder.newStreamWriter()->write(root, &std::cout);

这里有个让人费解的地方:
void StreamWriterBuilder::setDefaults(Json::Value* settings)看起来似乎是让一个 settings 对象成为 StreamWriterBuilder 全局默认的配置, 但实际上只是让一个配置重置成 ’ 默认 ’ 数据, 真是莫名其妙的用法 …

void StreamWriterBuilder::setDefaults(Json::Value* settings) {//! [StreamWriterBuilderDefaults]
  (*settings)["commentStyle"] = "All";
  (*settings)["indentation"] = "\t";
  (*settings)["enableYAMLCompatibility"] = false;
  (*settings)["dropNullPlaceholders"] = false;
  (*settings)["useSpecialFloats"] = false;
  (*settings)["precision"] = 17;
  (*settings)["precisionType"] = "significant";
  //! [StreamWriterBuilderDefaults]
}

正文完
 0