0

0

C++怎么解析JSON数据 C++ JsonCpp库使用快速入门【开发】

裘德小鎮的故事

裘德小鎮的故事

发布时间:2026-01-25 12:54:10

|

322人浏览过

|

来源于php中文网

原创

JsonCpp是轻量易用的C++ JSON库,适合嵌入式等场景,但需注意内存管理、类型安全访问(isMember+asXxx)、正确链接、UTF-8处理及Value深拷贝陷阱。

c++怎么解析json数据 c++ jsoncpp库使用快速入门【开发】

JsonCpp 是 C++ 里最轻量、最易上手的 JSON 解析库之一,适合嵌入式、命令行工具或不需要完整生态的项目;但它的设计偏 C 风格,容易在内存管理、类型转换和错误处理上踩坑。

怎么安装 JsonCpp(Linux/macOS + CMake)

多数现代发行版已打包,优先用包管理器安装,避免手动编译出错:

  • Ubuntu/Debian:sudo apt install libjsoncpp-dev,头文件自动到 /usr/include/json/json.h
  • macOS(Homebrew):brew install jsoncpp,头文件路径通常是 /opt/homebrew/include/json/json.h
  • 若需静态链接或自定义构建:从 https://github.com/open-source-parsers/jsoncpp 克隆后用 cmake -DBUILD_SHARED_LIBS=OFF && make install

注意:CMakeLists.txt 中必须显式 link jsoncpp,否则链接时报 undefined reference to `Json::Value::Value(Json::ValueType)` —— 这是最常见的“装了却用不了”错误。

怎么读取字符串并提取字段(Value 类型安全访问)

Json::Value 是核心容器,但它的 [] 操作符不检查键是否存在,直接访问缺失字段会静默创建空对象,导致逻辑错误。务必用 isMember() + asXxx() 组合:

立即学习C++免费学习笔记(深入)”;

Gaga
Gaga

曹越团队开发的AI视频生成工具

下载
#include 
#include 

std::string json_str = R"({"name":"Alice","age":30,"active":true})";
Json::CharReaderBuilder builder;
Json::Value root;
JSONCPP_STRING errs;
if (!Json::parseFromStream(builder, std::istringstream(json_str), &root, &errs)) {
    std::cerr << "Parse error: " << errs << std::endl;
    return;
}

if (root.isMember("name") && root["name"].isString()) {
    std::string name = root["name"].asString(); // 安全
}
if (root.isMember("age") && root["age"].isInt()) {
    int age = root["age"].asInt(); // 不要用 asUInt() 除非确定非负
}
// ❌ 错误写法:int age = root["age"].asInt(); // 缺少 isMember/isInt 检查,可能返回 0 误导逻辑

怎么生成 JSON 字符串(避免中文乱码和格式控制)

默认 Json::StreamWriterBuilder 输出无缩进、无换行,且对 UTF-8 字符串不做转义 —— 如果输入含中文,直接输出是正常的;但若原始字符串是 GBK 或其他编码,需先转 UTF-8 再塞进 Json::Value

  • 要美化输出(带缩进):设置 builder["indentation"] = " ";
  • 要禁止转义 Unicode(让中文原样显示而非 \u4f60):设置 builder["emitUTF8"] = true;
  • 要生成紧凑格式(如 HTTP body):保持默认,或设 builder["indentation"] = "";

示例:

Json::StreamWriterBuilder builder;
builder["indentation"] = "  ";
builder["emitUTF8"] = true;
std::string output = Json::writeString(builder, root);

常见崩溃点:Value 生命周期与深拷贝陷阱

Json::Value 默认是浅拷贝语义,但内部引用计数管理较隐晦。以下操作极易引发 double-free 或悬空引用:

  • 把局部 Json::Value 的引用(Json::Value&)存入容器或返回给调用方 —— 函数退出后引用失效
  • operator= 赋值后,原对象仍持有部分资源,尤其在频繁增删字段时
  • 混用 Json::ValueJson::Value*,又忘了 delete(它不是智能指针)

稳妥做法:始终按值传递 Json::Value,或明确使用 std::unique_ptr<:value> 管理动态分配对象;解析后立即转成业务结构体,别长期持有 Json::Value 实例。

相关专题

更多
json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

417

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

535

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

311

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

76

2025.09.10

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

278

2023.08.03

js截取字符串的方法
js截取字符串的方法

js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

212

2023.09.04

java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1493

2023.10.24

字符串介绍
字符串介绍

字符串是一种数据类型,它可以是任何文本,包括字母、数字、符号等。字符串可以由不同的字符组成,例如空格、标点符号、数字等。在编程中,字符串通常用引号括起来,如单引号、双引号或反引号。想了解更多字符串的相关内容,可以阅读本专题下面的文章。

622

2023.11.24

c++ 根号
c++ 根号

本专题整合了c++根号相关教程,阅读专题下面的文章了解更多详细内容。

41

2026.01.23

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PostgreSQL 教程
PostgreSQL 教程

共48课时 | 7.7万人学习

Git 教程
Git 教程

共21课时 | 3万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号