日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > c/c++ >内容正文

c/c++

C++用库 jsoncpp 解析 JSON

發布時間:2025/3/21 c/c++ 19 豆豆
生活随笔 收集整理的這篇文章主要介紹了 C++用库 jsoncpp 解析 JSON 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

使用C++處理JSON數據交換格式(轉自http://hi.baidu.com/%D3%C3%B1%F8%C8%E7%C9%F1garbin/blog/item/85c602edd7f9a7fbcf1b3e49.html)

一、摘要

????JSON的全稱為:JavaScript Object Notation,顧名思義,JSON是用于標記Javascript對象的,JSON官方的解釋為:

JSON是一種輕量級的數據傳輸格式。

本文并不詳細介紹JSON本身的細節,旨在討論如何使用C++語言來處理JSON。關于JSON更具體的信息,

可參見JSON官網:http://www.json.org

?

二、本文選擇處理JSONC++

???本文選擇一個第三方庫jsoncpp來解析JSONjsoncpp是比較出名的C++ JSON解析庫。在JSON官網也是首推的。

下載地址為:http://sourceforge.net/projects/jsoncpp。本文使用的jsoncpp版本為:0.5.0

?

三、jsoncppWindows下的編譯

要使用第三方源碼庫,第一步少不了的就是編譯,將源碼文件編譯成我們方便使用的動態鏈接庫、靜態鏈接庫或者靜態導入庫[1]

jsconcpp進行JSON解析的源碼文件分布在include/jsonsrc/lib_json下。其實jsoncpp源碼并不多,為了方便產品管理,

此處沒必要將其編譯為動態鏈接庫或者靜態導入庫,所以我們選擇使用靜態鏈接庫[2]

jsoncpp已經處理的很完善了,所有編譯選項都已經配置好,打開makefiles/vs71/jsoncpp.sln便可以開始編譯(默認是使用VS2003

譯器的,打開時直接按照VS2005提示轉換即可)。

?

四、jsoncpp使用詳解?

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

????Json::Value只能處理ANSI類型的字符串,如果C++程序是用Unicode編碼的,最好加一個Adapt類來適配。?

1Value?

????Json::Valuejsoncpp中最基本、最重要的類,用于表示各種類型的對象,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類型。

注:跟C++不同,JavaScript數組可以為任意類型的值,所以jsoncpp也可以。

???如上幾個用法已經可以滿足絕大部分json應用了,當然jsoncpp還有一些其他同能,比如說設置注釋、比較json

大小、交換json對象等,都很容易使用,大家自己嘗試吧。

2Writer

如上說了Json::Value的使用方式,現在到了該查看剛才賦值內容的時候了,查看json內容,使用Writer類即可。

JsoncppJson::Writer類是一個純虛類,并不能直接使用。在此我們使用Json::Writer的子類:Json::FastWriterJson::StyledWriterJson::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"?

}

3Reader

????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字符串。

?--------------------------------------?

[1]:使用第三方源碼最簡單的方法是直接將文件加入工程,但這樣不利于源碼、軟件產品管理,對于一般軟件開發來說,不建議使用。

[2]:如果真需要編譯成動態鏈接庫、靜態導入庫的話,可以使用VS新建一個工程屬性,然后在Project --> Properties中進行相應的設置即可。


總結

以上是生活随笔為你收集整理的C++用库 jsoncpp 解析 JSON的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。