当前位置: 首页 > article >正文

jsoncpp 使用说明(ubuntu)

1、安装:

sudo apt install -y libjsoncpp-dev

2、配置:

Cmakelist配置:

set(JSONCPP_INCLUDE_DIRS /path/to/jsoncpp/include)  

set(JSONCPP_LIBRARIES /path/to/jsoncpp/lib/libjsoncpp.so)

find_package(PkgConfig REQUIRED)  

pkg_check_modules(JSONCPP REQUIRED jsoncpp)

include_directories(${JSONCPP_INCLUDE_DIRS})  

target_link_libraries(your_executable_name ${JSONCPP_LIBRARIES})  

3、使用:

JsonCpp 主要包含三种类型的 class:

Json::Value:可以表示所有支持的类型,如:int , double ,string , object, array等。其包含节点的类型判断(isNull,isBool,isInt,isArray,isMember,isValidIndex等),类型获取(type),类型转换(asInt,asString等),节点获取(get,[]),节点比较(重载<,<=,>,>=,==,!=),节点操作(compare,swap,removeMember,removeindex,append等)等函数。

Json::Reader:将文件流或字符串创解析到Json::Value中,主要使用parse函数Json::Reader的构造函数还允许用户使用特性Features来自定义Json的严格等级。

Json::Writer:与JsonReader相反,将Json::Value转换成字符串流等,Writer类是一个纯虚类,并不能直接使用。在此我们使用 Json::Writer 的子类:Json::FastWriter(将数据写入一行,没有格式),Json::StyledWriter(按json格式化输出,易于阅读)

4、参考示例:

{
  "content": "Hello JsonCpp"}

使用 Reader 和 Value 读取 content 的值:

#include <string>
#include <iostream>
#include <json/json.h>

int main(int argc, char const *argv[])
{
  
    std::string str = "{\"content\": \"Hello JsonCpp\"}";

    Json::Reader reader;
    Json::Value root;
    if (reader.parse(str, root))
        std::cout << root["content"].asString() << std::endl;
    
    return 0;
}

调用 Reader.parse() 接口尝试解析 json 字符串 str,当 str 满足 json 格式之后,调用 Value 的 [] 操作符将 “content” 的值取出来,然后再进行类型转换,取出实际的类型数据。

值类型

JsonCpp 支持的值类型总共有 8 种:

enumValueTypeDescription
0nullValue‘null’ value
1intValuesigned integer value
2unsigned intunsigned integer value
3realValuedouble value
4stringValueUTF-8 string value
5booleanValuebool value
6arrayValuearray value (ordered list)
7objectValueobject value (collection of name/value pairs)

类型判断

如果需要进行类型判断,Json::Value 已经提供了完备的类型判断接口供调用:

class Value {
  
    ...
    bool isNull() const;
    bool isBool() const;
    bool isInt() const;
    bool isInt64() const;
    bool isUInt() const;
    bool isUInt64() const;
    bool isIntegral() const;
    bool isDouble() const;
    bool isNumeric() const;
    bool isString() const;
    bool isarray() const;
    bool isObject() const;
    ...
};

其中这里有两个接口比较特殊,一个是 isNumeric() 另一个是 isIntegral()

先对 isNumeric() 进行说明,字面意思就是“是否为数字”,实际上在 Json::Value 类的实现中等同于 isDouble(),因此这两个函数是等效的

键值判断

Value.isMember() 接口用于判断 json 字符串中是否存在某个键值,

参考地址:

JsonCpp 使用指导-菜鸟笔记 (coonote.com)


http://www.kler.cn/a/281525.html

相关文章:

  • 自定义tabbar跳转防止页面抖动(uniapp案例,也适用所有前端项目)
  • 近期29√28 冲击七连红,周五意甲 威尼斯VS都灵 比赛分析 比分预测 免费获取,重榜二串一来了
  • Sui Move HackerHouse@成都圆满落幕,静候下次精彩!
  • 机器学习:集成学习之随机森林
  • 网络安全总结①
  • 【百日算法计划】:每日一题,见证成长(001)
  • 展锐7870 Camera HAL层日志调试
  • MySQL 查询优化详解
  • JAVA如何使用反射突破泛型的限制
  • 全国上市公司网络安全风险指数(2001-2023年)
  • 【面试经验】字节跳动 商业化产品经理面经回顾
  • 分子属性梯度引导的3D分子生成扩散模型 TAGMOL - 评测
  • 软件测试学习笔记丨静态测试与代码审计 SonarQube
  • Android 开发兼容性问题,TaskExecutionException等问题。
  • Redis一些问题
  • 【精选】基于数据可视化的智慧社区内网平台(程序员阿龙出品精品)
  • 开源项目管理工具Taiga
  • 【jvm】虚拟机栈是如何运行的
  • eureka原理与实践简单介绍
  • IOS、OSX逆向工具关系分析