jsoncpp使用小结

一、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["FaceItemObjects"].resize(0);  
std::string strJson = root.toStyledString();

示例4:序列化复杂json字符串

Json::Value root;
Json::Value itemFaceArray;
Json::value itemFace;
root["errorCode"] = 0;
root["faces"].resize(0);
//face1
itemFace["x"]=1;
itemFace["y"]=1;
itemFace["width"]=100;
itemFace["height"]=100;
itemFace["score"]=95;
itemFaceArray.append(itemFace);
//face2
itemFace.clear();
itemFace["x"]=200;
itemFace["y"]=200;
itemFace["width"]=100;
itemFace["height"]=100;
itemFace["score"]=98;
itemFaceArray.append(itemFace);
root["faces"] = itemFaceArray;
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、获取json中不存在名称的值,并且作为asCString()拷贝时,程序会core。如strncpy(a, root["test"].asCString(), sizeof(a));

3、解决jsoncpp中文输出为unicode格式的"\u"、VS读取utf8格式中文输出乱码问题。
参考:https://blog.csdn.net/wgxh05/article/details/82792729

4、fatal error C1083: 无法打开编译器生成的文件:“../../build/vs71/release/lib_json\json_value.asm”: No such file or directory 

解决方法:修改生成静态库文件的工程的属性:路径为:菜单---项目--属性---配置属性---c/c++---输出文件---汇编程序输出:无列表

5、异常捕获

bool bReadJsonSuccess = false;
try
{
    Json::Reader reader;
    string json_document = "{\"age\" : 123, \"name\" : \"weng\"}";
    if (!reader.parse(json_document, json_object))
    {
            cout << "error" << endl;
            bReadJsonSuccess = false;
    }
    else
    {
          cout <<"age:" <<json_object["age"] << " name" << json_object["name"] << endl;
          bReadJsonSuccess = true;
    }
}
catch(...)
{
    bReadJsonSuccess = false;
}

 

©️2020 CSDN 皮肤主题: 技术工厂 设计师: CSDN官方博客 返回首页
实付0元
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值