JSON用法簡介

來源:互聯網
上載者:User

標籤:簡介   boolean   支援   基本   char   例子   ade   純虛類   物件類型   

JSON簡介

  jsoncpp 主要包含三種類型的 class:Value、Reader、Writer。jsoncpp 中所有對象、類名都在 namespace Json 中,包含 json.h 即可。

VALUE

   Json::Value 是jsoncpp 中最基本、最重要的類,用於表示各種類型的對象,jsoncpp 支援的物件類型可見 Json::ValueType 枚舉值。  

  可如下是用 Json::Value 類:

  Json::Value json_temp;      // 臨時對象,供如下代碼使用

  json_temp["name"] = Json::Value("huchao");

  json_temp["age"] = Json::Value(26);

  Json::Value root;  // 表示整個 json 對象

  root["key_string"] = Json::Value("value_string");         // 建立一個 Key(名為:key_string),賦予字串值:"value_string"。

  root["key_number"] = Json::Value(12345);            // 建立一個 Key(名為:key_number),賦予數值:12345。

  root["key_boolean"] = Json::Value(false);              // 建立一個 Key(名為:key_boolean),賦予bool值:false。

  root["key_double"] = Json::Value(12.345);            // 建立一個 Key(名為:key_double),賦予 double 值:12.345。

  root["key_object"] = Json_temp;                           // 建立一個 Key(名為:key_object),賦予 json::Value 對象值。

  root["key_array"].append("array_string");             // 建立一個 Key(名為:key_array),類型為數組,對第一個元素賦值為字串:"array_string"。

  root["key_array"].append(1234);                           // 為數組 key_array 賦值,對第二個元素賦值為:1234。

  Json::ValueType type = root.type();                       // 獲得 root 的類型,此處為 objectValue 類型。

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"

  }

VALUE

   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用法簡介

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.