网站首页 > 技术文章 正文
一、jsoncpp介绍
jsoncpp是一个开源C++库,提供对JSON字符串序列化/反序列化的能力,开源地址:https://github.com/open-source-parsers/jsoncpp,文档地址:http://open-source-parsers.github.io/jsoncpp-docs/doxygen/index.html。
二、jsoncpp的使用
jsoncpp主要包含三种类型的C++类 - value、reader、writer。value表示json对象和数组。reader用于反序列化json字符串。writer用于序列化json字符串。简单使用示例:
示例1:生成json
Json::Value jsonRoot; //定义根节点
Json::Value jsonItem; //定义一个子对象
jsonItem["item1"] = "one"; //添加数据
jsonItem["item2"] = 2;
jsonRoot.append(jsonItem);
jsonItem.clear(); //清除jsonItemjsonItem["item1.0"] = 1.0;
jsonItem["item2.0"] = 2.0;
jsonRoot["item"] = jsonItem;
std::string strJson = jsonRoot.toStyledString(); //json结果
示例2:读取json
Json::Reader reader;
string json_document = "{\"age\" : 123, \"name\" : \"weng\"}";
if (!reader.parse(json_document, json_object))
{
cout << "error" << endl;
return 0;
}
else
{
cout <<"age:" <<json_object["age"] << " name" << json_object["name"] << endl;
}
示例3:构造空数组
Json::Value root;
root["FurniturePlaceItemObject"].resize(0);
std::string strJson = root.toStyledString();
三、注意事项
1、jsoncpp不支持int64位的。
解决方法1:需要0.6.0rc2版本。 不要采用0.5.0版本,因为它没有64位int。
解决方法2:0.5.0版本基础上修改代码支持64位int。具体参考https://sourceforge.net/p/jsoncpp/discussion/483465/thread/3610921c/
解决方法3:asUInt换成asDouble
Json::Reader reader;
Json::Value root;
if (reader.parse(str, root))
{
//获取里面内容
OutputDebugString(_T("STRING TO JSON \n"));
//std::string str1 = root["messageType"].asString();
long long tmstamp = ((long long)(root["sendTime"].asUInt()))/1000;
WCHAR* wstr = NULL;
TimestampToLocalTime(&wstr,tmstamp);
}
结果发现第8行会出错,查了下错误原因, 原来SendTime是一个以毫秒为单位的时间戳,其值为1403575350411,这个值的大小远远超出了 unsigned int 或者 int的最大值,只能用INT64来表示, 但是看看Json::Value里面的函数只有asInt, asUint,没有取64位整数的函数,那怎么办呢?里面虽然没有64位的但是有一个asDouble,duoble的指数为11位,能表示的范围比Int64还大,所以上面的asUInt换成asDouble就可以了。
解决方法4:使用高版本(比如1.8.4),在使用jsoncpp库的工程属性预定义中增加JSON_HAS_INT64
2、对数据类型赋值比较严格。(比如将""引起来的字符串赋值给另一种类型,会报错 )
3、获取json中不存在名称的值,并且作为asCString()拷贝时,程序会core。如strncpy(a, root["test"].asCString(), sizeof(a));
4、fatal error C1083: 无法打开编译器生成的文件:“../../build/vs71/release/lib_json\json_value.asm”: No such file or directory
解决方法:修改生成静态库文件的工程的属性:路径为:菜单---项目--属性---配置属性---c/c++---输出文件---汇编程序输出:无列表
猜你喜欢
- 2025-01-13 postman——post请求数据类型
- 2025-01-13 比较一下JSON与XML两种数据格式?
- 2025-01-13 JSON&Ajax介绍和实例
- 2025-01-13 NET Core处理WebAPI JSON返回null为空
- 2025-01-13 微信WeUI设计规范文件下载及使用方法
- 2025-01-13 Spring Boot 中使用 JSON Schema 来校验复杂JSON数据
- 2025-01-13 C#解析多层嵌套的JSON数组
- 2025-01-13 web后端正确的返回JSON
- 2025-01-13 3分钟短文 | Linux 使用curl发起post请求的4个常用方式
- 2025-01-13 今日头条 iOS 安装包大小优化 - 新阶段、新实践
你 发表评论:
欢迎- 577℃几个Oracle空值处理函数 oracle处理null值的函数
- 573℃Oracle分析函数之Lag和Lead()使用
- 559℃Oracle数据库的单、多行函数 oracle执行多个sql语句
- 557℃0497-如何将Kerberos的CDH6.1从Oracle JDK 1.8迁移至OpenJDK 1.8
- 554℃Oracle 12c PDB迁移(一) oracle迁移到oceanbase
- 543℃【数据统计分析】详解Oracle分组函数之CUBE
- 531℃最佳实践 | 提效 47 倍,制造业生产 Oracle 迁移替换
- 527℃Oracle有哪些常见的函数? oracle中常用的函数
- 最近发表
- 标签列表
-
- 前端设计模式 (75)
- 前端性能优化 (51)
- 前端模板 (66)
- 前端跨域 (52)
- 前端缓存 (63)
- 前端react (48)
- 前端aes加密 (58)
- 前端脚手架 (56)
- 前端md5加密 (54)
- 前端富文本编辑器 (47)
- 前端路由 (61)
- 前端数组 (73)
- 前端js面试题 (50)
- 前端定时器 (59)
- Oracle RAC (73)
- oracle恢复 (76)
- oracle 删除表 (48)
- oracle 用户名 (74)
- oracle 工具 (55)
- oracle 内存 (50)
- oracle 导出表 (57)
- oracle 中文 (51)
- oracle的函数 (57)
- 前端调试 (52)
- 前端登录页面 (48)
本文暂时没有评论,来添加一个吧(●'◡'●)