C++ jsoncpp编译及链接库的使用
2017-11-23 16:42
239 查看
1. Jsoncpp介绍
(1)JsonCpp主要包含三种类型的class:Value Reader Writer;
Json::Value 是jsoncpp 中最基本、最重要的类,用于表示各种类型的对象,jsoncpp 支持的对象类型可见 Json::ValueType 枚举值。
Json::Reader 是用于读取的,说的确切点,是用于将字符串转换为 Json::Value 对象的。
Json::Writer 类是一个纯虚类,并不能直接使用。在此我们使用 Json::Writer 的子类:Json::FastWriter、Json::StyledWriter、Json::StyledStreamWriter。
(2)Jsoncpp中所有对象、类名都在namespace json中,包含json.h即可
2. Jsoncpp的下载与编译
下载下来的jsoncpp必须要编译才能使用,在ubuntut上使用如下:
apt-get install scons
####下载jsoncpp-src-0.5.0.tar.gz######
tar -xvzf jsoncpp-src-0.5.0.tar.gz
cd jsoncpp-src-0.5.0
scons platform=linux-gcc
gcc版本是4.6的,上面的命令执行完后,会在jsoncpp-src-0.5.0/libs/linux-gcc-4.6目录下面生成库文件:
(1)libjson_linux-gcc-4.6_libmt.a
(2)libjson_linux-gcc-4.6_libmt.so
之后,将动态链接库libjson_linux-gcc-4.6_libmt.so,添加到搜索路径中,
参照:linux找不到动态链接库 .so文件的解决方法 http://www.cnblogs.com/xudong-bupt/p/3698294.html
3.Jsoncpp使用代码示例
3.1 程序解析json数据
解析下面的文件JsonText,文件如下:
{
"name": "json",
"array": [
"123",
"456",
"789"
]
}
代码(c.cpp):
#include "json/json.h"
#include <string>
#include <stdlib.h>
#include <iostream>
#include <fstream>
using namespace std;
int main()
{
ifstream is;
is.open ("JsonText", std::ios::binary );
Json::Reader reader;
Json::Value root;
if(reader.parse(is,root)) ///root保存整个Json对象的value
{
if(!root["name"].isNull())
{
cout<<root["name"].asString()<<endl; ///读取元素
Json::Value arrayObj = root["array"];
for(int i=0 ; i< arrayObj.size() ;i++)
{
cout<<arrayObj[i].asString()<<endl;
}
}
}
return 0;
}
编译、链接、执行:
g++ c.cpp -I ./include/ -L./libs/linux-gcc-4.6/ -ljson_linux-gcc-4.6_libmt -o C
./C
执行结果:
json
123
456
789
3.2 程序生成json数据
代码:
#include <iostream>
#include <string>
#include "json/json.h"
int main(void)
{
Json::Value root;
Json::Value arrayObj;
Json::Value item;
for (int i = 0; i < 2; i ++)
{
item["key"] = i;
//arrayObj.append(item); ///给arrayObj中添加元素(arrayObj变为数组)
arrayObj.append(i); ///给arrayObj中添加元素(arrayObj变为数组)
}
root["key1"] = "value1"; ///给root中添加属性(arrayObj变为map)
root["key2"] = "value2";
root["array"] = arrayObj;
//root.toStyledString();
std::string out = root.toStyledString(); ///转换为json格式字符串
std::cout << out << std::endl;
return 0;
}
编译、链接、执行:
g++ b.cpp -I ./include/ -L./libs/linux-gcc-4.6/ -ljson_linux-gcc-4.6_libmt -o B
./B
执行结果:
{
"array" : [ 0, 1 ],
"key1" : "value1",
"key2" : "value2"
}
(1)JsonCpp主要包含三种类型的class:Value Reader Writer;
Json::Value 是jsoncpp 中最基本、最重要的类,用于表示各种类型的对象,jsoncpp 支持的对象类型可见 Json::ValueType 枚举值。
Json::Reader 是用于读取的,说的确切点,是用于将字符串转换为 Json::Value 对象的。
Json::Writer 类是一个纯虚类,并不能直接使用。在此我们使用 Json::Writer 的子类:Json::FastWriter、Json::StyledWriter、Json::StyledStreamWriter。
(2)Jsoncpp中所有对象、类名都在namespace json中,包含json.h即可
2. Jsoncpp的下载与编译
下载下来的jsoncpp必须要编译才能使用,在ubuntut上使用如下:
apt-get install scons
####下载jsoncpp-src-0.5.0.tar.gz######
tar -xvzf jsoncpp-src-0.5.0.tar.gz
cd jsoncpp-src-0.5.0
scons platform=linux-gcc
gcc版本是4.6的,上面的命令执行完后,会在jsoncpp-src-0.5.0/libs/linux-gcc-4.6目录下面生成库文件:
(1)libjson_linux-gcc-4.6_libmt.a
(2)libjson_linux-gcc-4.6_libmt.so
之后,将动态链接库libjson_linux-gcc-4.6_libmt.so,添加到搜索路径中,
参照:linux找不到动态链接库 .so文件的解决方法 http://www.cnblogs.com/xudong-bupt/p/3698294.html
3.Jsoncpp使用代码示例
3.1 程序解析json数据
解析下面的文件JsonText,文件如下:
{
"name": "json",
"array": [
"123",
"456",
"789"
]
}
代码(c.cpp):
#include "json/json.h"
#include <string>
#include <stdlib.h>
#include <iostream>
#include <fstream>
using namespace std;
int main()
{
ifstream is;
is.open ("JsonText", std::ios::binary );
Json::Reader reader;
Json::Value root;
if(reader.parse(is,root)) ///root保存整个Json对象的value
{
if(!root["name"].isNull())
{
cout<<root["name"].asString()<<endl; ///读取元素
Json::Value arrayObj = root["array"];
for(int i=0 ; i< arrayObj.size() ;i++)
{
cout<<arrayObj[i].asString()<<endl;
}
}
}
return 0;
}
编译、链接、执行:
g++ c.cpp -I ./include/ -L./libs/linux-gcc-4.6/ -ljson_linux-gcc-4.6_libmt -o C
./C
执行结果:
json
123
456
789
3.2 程序生成json数据
代码:
#include <iostream>
#include <string>
#include "json/json.h"
int main(void)
{
Json::Value root;
Json::Value arrayObj;
Json::Value item;
for (int i = 0; i < 2; i ++)
{
item["key"] = i;
//arrayObj.append(item); ///给arrayObj中添加元素(arrayObj变为数组)
arrayObj.append(i); ///给arrayObj中添加元素(arrayObj变为数组)
}
root["key1"] = "value1"; ///给root中添加属性(arrayObj变为map)
root["key2"] = "value2";
root["array"] = arrayObj;
//root.toStyledString();
std::string out = root.toStyledString(); ///转换为json格式字符串
std::cout << out << std::endl;
return 0;
}
编译、链接、执行:
g++ b.cpp -I ./include/ -L./libs/linux-gcc-4.6/ -ljson_linux-gcc-4.6_libmt -o B
./B
执行结果:
{
"array" : [ 0, 1 ],
"key1" : "value1",
"key2" : "value2"
}
相关文章推荐
- Linux Makefile自动编译和链接使用的环境
- vs2012 编译jsoncpp和使用jsoncpp lib出现的问题
- MOOS中使用CMake编译链接glog库
- GCC中同时使用动态和静态库链接的编译
- 使用gcc 5 编译c++11编写的程序 出现的符号找不到的链接问题。
- C++ 解析Json VC6 中编译、使用jsoncpp
- 使用clang命令行工具/终端直接 编译链接Objective-C应用程序
- 在Solaris上使用LD_OPTIONS环境变量诊断编译链接问题
- 【Linux】使用vim编写一个程序,gcc查看预处理、编译、汇编、链接过程
- 使用clang命令行工具编译链接Objective-C应用程序
- “为了能够访问动态链接库中的位图资源,在编译动态链接库时,需要使用MFC静态库”
- 在项目中使用libcurl,解决编译链接错误
- CentOS系统下使用maven编译javaCPP-ffmpeg
- C++编译与链接(0)-.h与.cpp中的定义与声明
- 深入理解预编译,编译,汇编,链接的过程——之编译和使用(链接)库——动态库
- 【汇编语言/底层开发】4、使用masm编译、链接汇编源文件
- oci库使用--引发的编译链接问题
- Linux环境下的编译,链接与库的使用
- 使用clang命令行工具编译链接Objective-C应用程序
- 拓展:使用终端创建、编译、链接OC…