如下代码:
QJsonArray actionsArray;
QJsonObject totalRootJson;
totalRootJson.insert("actionsArray", actionsArray);
/*此处尝试更新actionsArray,如:向数组actionsArray添加一个json的actionScripts对象 */
actionsArray.append(actionScripts);
// 这里再访问actionsArray
auto size = totalRootJson["actionsArray"].toArray().size(); // 返回0,即未追加子节点
auto child = totalRootJson["actionsArray"].toArray()[0]; // 因为没有子节点,会崩溃
调用QJsonObject的insert向totalRootJson插入一个QJsonArray类型的actionsArray,然后再更新actionsArray对象,如:追加一个QJsonObject的对象actionScripts到actionsArray对象,然后再访问actionsArray节点,发现actionsArray节点还是未更新之前的,即actionsArray节点未追加任何子节点,即第11行的size返回0,第12行因为不存在子节点导致索引越界崩溃。也就是说Qt的json对象不像指针、引用那样被改动、被更新就立马能在整个json文档中反应出来,解决上面问题办法是:把更新操作放在insert前面,如下:
QJsonArray actionsArray;
QJsonObject totalRootJson;
/*此处为更新actionsArray的代码,如:向数组 actionsArray添加一个json的actionScripts对象*/
actionsArray.append(actionScripts);
// insert放在append操作的后面
totalRootJson.insert("actionsArray", actionsArray);
// 这里再访问actionsArray
auto size = totalRootJson["actionsArray"].toArray().size(); // 返回1,即成功追加1个子节点
auto child = totalRootJson["actionsArray"].toArray()[0]; // 获取第1个子节点。即上面的actionScripts对象
又例如下json:
{
"actionScriptsGenerator":
[
{
"currentActionId": 0,
"moduleName": "Untitled0"
},
{
"currentActionId": 0,
"moduleName": "2"
}
]}
当要更新节点的值时,如:更新moduleName的值,则调用如下代码:
Obj.insert("moduleName", "dansir");
按照Qt Assist的解释,如果指定的键存在了,则更新,调试发现obj的moduleName对应的值确实更新了,但是查看包含obj的父或祖父节点(本例为actionScriptsGenerator数组的第1个元素或json根文档对象),发现obj没有变化,还是原来的值。解决方法如下:
QJsonObject newObj;
newObj.insert("moduleName", "dansir");
actionScriptsGenerator.replace(0, newObj);
其中actionScriptsGenerator为QJsonArray对象,0表示actionScriptsGenerator数组对象的第一个元素即obj对象,即用新值创建一个新对象,然后用这个新对象替换掉原来旧的对象。
博客探讨了在Qt中使用QJsonObject和QJsonArray时遇到的问题,即更新QJsonArray后,该更新并未立即反映在已插入QJsonObject的QJsonArray中。解决方法是先更新QJsonArray,再将其插入QJsonObject。同样,更新QJsonObject的某个字段后,其父或祖父节点未见更新,需要创建新对象并替换原有对象。示例代码展示了具体操作步骤。
368

被折叠的 条评论
为什么被折叠?



