linux编译jsoncpp

jsoncpp简介:

        jsoncpp是一个 C++ 库,用于实现json格式的序列化和反序列化,完成多个数据对象组织成为json格式字符串,以及将json格式字符串解析成得到多个数据对象的数据。它还可以在反序列化/序列化步骤中保留现有注释,使其成为存储用户输入文件的方便格式。

github地址:

官方网址:https://github.com/open-source-parsers/jsoncpp

编译:

修改 CMakeLists.txt,将 JSONCPP_WITH_TESTS 配置成 OFF,不去编译测试工程

jsoncpp编译:

cd jsoncpp/
mkdir install     # 创建安装目录
mkdir build       # 创建编译目录
cd build
cmake -DCMAKE_INSTALL_PREFIX=../install ..
make -j4          # 开始编译
make install      # 安装到install

jsoncpp交叉编译:

创建一个 toolchain.cmake 文件:

# This is required. target system name
SET(CMAKE_SYSTEM_NAME Linux)
SET(CMAKE_SYSTEM_PROCESSOR arm)
 
# specify the cross compiler
SET(TOOLCHAIN_PATH /opt/arm/opt/ext-toolchain/)
SET(CMAKE_SYSROOT ${TOOLCHAIN_PATH}/../../usr/arm-buildroot-linux-gnueabihf/sysroot)
SET(CMAKE_C_COMPILER   ${TOOLCHAIN_PATH}/bin/arm-linux-gnueabihf-gcc)
SET(CMAKE_CXX_COMPILER ${TOOLCHAIN_PATH}/bin/arm-linux-gnueabihf-g++)
 
# search for programs in the build host directories
SET(CMAKE_FIND_ROOT_PATH_MODE_PROGRAM NEVER)
 
# for libraries and headers in the target directories
SET(CMAKE_FIND_ROOT_PATH_MODE_LIBRARY ONLY)
SET(CMAKE_FIND_ROOT_PATH_MODE_INCLUDE ONLY)
SET(CMAKE_FIND_ROOT_PATH_MODE_PACKAGE ONLY)
cd jsoncpp/ 
mkdir install
mkdir build
cd build
# cmake -DCMAKE_TOOLCHAIN_FILE=../toolchain.cmake -DCMAKE_INSTALL_PREFIX=../install ..
cmake -DCMAKE_TOOLCHAIN_FILE=../toolchain.cmake \
      -DCMAKE_INSTALL_PREFIX=../arm-install \
      -DJSONCPP_WITH_TESTS=OFF \  # 关闭测试(减少依赖)
      -DBUILD_SHARED_LIBS=OFF \   # 生成静态库(默认动态库)
      ..
make
make install

jsoncpp使用:

jsoncpp中含有三种基础类:Value、Write、Reader。

  1. Json::Value:用于存储键值对
  2. Json::Writer
    这个类负责将内存中的value对象转换为json文档,输出到文件或者字符串中
    它有两种主要的方法:FastWriter、StyledWriter
    FastWriter:快速无格式的将value转换成json文档
    StyledWriter:有格式的将value转换成json文档
  3. Json::Reader
    用于读取json文档,或者说是用于将字符串或者文件输入流转换为Json::Value对象

实用函数

  1. 判断某个键是否存在,bool Json::Value::isMember(const char *key) const;若存在则返回1,反之为0
  2. 判断某个键的类型,bool Json::Value::isString(const char *key) const;是则返回1,反之为0
  3. 得到Value中的所有键,Json::Value::getMemberBames() const;返回一个string类型的vector
  4. 删除某个键,Json::Value::removeMember(const char *key);返回删除的值或者null

测试demo

#include <iostream>
#include <fstream>
#include "json/json.h"

#if defined(__GNUC__)
#pragma GCC diagnostic push
#pragma GCC diagnostic ignored "-Wdeprecated-declarations"
#elif defined(_MSC_VER)
#pragma warning(disable : 4996)
#endif

using namespace std;

int createjson()
{
    Json::Value root;
    Json::Value language;
    Json::Value mail;
    Json::StyledWriter writer;     # 格式化json串
    // Json::FastWriter writer;    # 压缩json串

    root["Name"] = "pikashu";
    root["Age"] = 18;

    language[0] = "C++";
    language[1] = "Python";
    root["Language"] = language;

    mail["QQ"] = "789123456@qq.com";
    mail["Google"] = "789123456@gmail.com";
    root["E-mail"] = mail;

    string json_file = writer.write(root);

    ofstream ofs;
    ofs.open("test1.json");
    if (!ofs.is_open())
    {
        cout << "open file error." << endl;
        return -1;
    }
    ofs << json_file;
    ofs.close(); 
    return 0;
}

int readjson()
{
    Json::Reader reader;
    Json::Value root;
    Json::Value language;
    Json::Value mail;

    ifstream ifs;
    ifs.open("test1.json");
    if (!ifs.is_open())
    {
        cout << "open file error." << endl;
        return -1;
    }

    if (!reader.parse(ifs, root))
    {
        cout << "parse error" << endl;
        return -1;
    }

    string Name = root["Name"].asString();
    int Age = root["Age"].asInt();  // jsoncpp中获取int类型数据
    cout << "Name: " << Name << endl;
    cout << "Age: " << Age << endl;

    if (root["language"].isArray())
    {
        Json::Value array_l = root["language"];
        cout << "Language: ";
        for (int i = 0; i < array_l.size(); i++)
        {
            cout << array_l[i] << " ";
        }
        cout << endl;
    }

    cout << "Google: " << root["E-mail"].get("Google", "").asString() << endl;
    cout << "QQ: " << root["E-mail"].get("QQ", "").asString() << endl;

    return 1;
}
int main()
{
    createjson();
    readjson();
    return 0;
}

参考:

交叉编译jsoncpp_jsoncpp交叉编译_蒋禾的博客-优快云博客

https://www.cnblogs.com/nazhen/p/16800412.html

Linux系统上使用CMake编译`jsoncpp`库的过程相对简单。`jsoncpp`是一个C++实现的JSON解析库,广泛用于需要处理JSON格式数据的项目中。以下是详细的编译步骤和相关说明: ### 获取源码 首先,需要从GitHub仓库获取`jsoncpp`的源码。可以通过以下命令克隆仓库: ```bash git clone https://github.com/open-source-parsers/jsoncpp.git cd jsoncpp ``` ### 创建构建目录 为了保持源码目录的整洁,建议在源码目录外创建一个独立的构建目录。可以通过以下命令创建并进入该目录: ```bash mkdir build cd build ``` ### 配置CMake 接下来,使用CMake来配置构建环境。可以通过以下命令执行配置: ```bash cmake -DCMAKE_BUILD_TYPE=Release -DBUILD_STATIC_LIBS=ON -DBUILD_SHARED_LIBS=ON .. ``` - `-DCMAKE_BUILD_TYPE=Release` 指定构建类型为Release,生成优化的库文件。 - `-DBUILD_STATIC_LIBS=ON` 启用静态库的构建。 - `-DBUILD_SHARED_LIBS=ON` 启用动态库的构建。 ### 编译库文件 配置完成后,可以使用`make`命令开始编译库文件。为了加快编译速度,可以使用多线程编译: ```bash make -j$(nproc) ``` ### 安装库文件 编译完成后,可以将生成的库文件安装到系统目录中。通常需要使用`sudo`权限来执行安装: ```bash sudo make install ``` 默认情况下,`jsoncpp`会被安装到`/usr/local`目录下。如果需要安装到其他位置,可以在配置CMake时指定安装路径: ```bash cmake -DCMAKE_INSTALL_PREFIX=/opt/jsoncpp .. ``` ### 验证安装 安装完成后,可以通过以下命令验证库文件是否成功安装: ```bash ls /usr/local/lib/libjsoncpp* ``` 这将列出所有安装的`jsoncpp`库文件,包括静态库和动态库。 ### 使用jsoncpp库 在编写使用`jsoncpp`的应用程序时,需要包含相应的头文件,并在编译时链接`jsoncpp`库。例如,编写一个简单的测试程序: ```cpp #include <json/json.h> #include <iostream> int main() { Json::Value root; root["name"] = "John Doe"; root["age"] = 25; Json::FastWriter writer; std::cout << writer.write(root) << std::endl; return 0; } ``` 编译该程序时,需要链接`jsoncpp`库: ```bash g++ test.cpp -o test -ljsoncpp ``` 通过以上步骤,即可在Linux系统上使用CMake编译并使用`jsoncpp`库[^3]。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值