C++常用 json 库有:
Jsoncpp
boost ison
Qt Json (不推荐使用)
nlohman::json (推荐使用)
其中Qt中json解析的相关类只在qt中有用,为了避免以后不用qt无法解析json,建议使用nlohmann/json,适用于任何C++框架。
1. 简介
nlohmann是一个C++的JSON库,它提供了方便的方式来解析、生成和操作JSON数据。该库由nlohmann编写,是一个开源项目,被广泛应用于C++开发中。
nlohmann库提供了简单易用的API,可以轻松地将JSON数据解析为C++对象,或者将C++对象序列化为JSON数据。它支持各种数据类型,包括字符串、数字、布尔值、数组和对象等。我们可以使用简洁的语法来访问和操作JSON数据,使得编写JSON处理代码变得更加简单和高效。
除了基本的JSON解析和生成功能,nlohmann库还提供了一些高级功能,如JSON合并、JSON差异比较、JSON数据查询等。这些功能可以帮助我们更方便地处理复杂的JSON数据,提高代码的可维护性和可读性。
2. 下载
下载地址:GitHub - nlohmann/json: JSON for Modern C++
将 single_include/nlohmann/json.hpp包含至自己的工程目录下及可使用,没有.cpp
文件。
3. 操作 json 示例
main.cpp
#include <iostream>
#include "nlohmann/json.hpp"
int main() {
// 使用nlohmann::json命名空间
using json = nlohmann::json;
// 定义一个JSON字符串
std::string json_string = R"(
{
"name": "John",
"age": 30,
"city": "New York",
"married": true,
"children": ["Alice", "Bob"],
"pets": {
"dog": "Charlie",
"cat": "Luna"
}
}
)";
// 解析JSON字符串到json对象
json j = json::parse(json_string);
// 访问JSON数据
std::cout << "Name: " << j["name"] << std::endl;
std::cout << "Age: " << j["age"] << std::endl;
std::cout << "City: " << j["city"] << std::endl;
std::cout << "Married: " << std::boolalpha << j["married"] << std::endl; // 使用std::boolalpha来打印bool值
std::cout << "Children: ";
for (const auto& child : j["children"]) {
std::cout << child << " ";
}
std::cout << std::endl;
// 访问嵌套的JSON对象
std::cout << "Pets:" << std::endl;
std::cout << " Dog: " << j["pets"]["dog"] << std::endl;
std::cout << " Cat: " << j["pets"]["cat"] << std::endl;
return 0;
}
笔者使用VScode,确保tasks.json
或launch.json
配置文件中包含了正确的编译器和编译选项。编译器需要支持C++11或更高版本,因为nlohmann/json
库需要C++11特性。例如,你的tasks.json
文件可能看起来像这样:
{
"version": "2.0.0",
"tasks": [
{
"type": "shell",
"label": "g++ build active file",
"command": "g++",
"args": [
"-std=c++11",
"-g",
"${file}",
"-o",
"${fileDirname}/${fileBasenameNoExtension}"
],
"options": {
"cwd": "/usr/bin"
},
"problemMatcher": [
"$gcc"
],
"group": {
"kind": "build",
"isDefault": true
}
}
]
}
参考: