QJsonObject的 常用接口

QJsonObject是用于表示JSON对象的类,包含键值对且键唯一,值由QJsonValue表示。它可以与QVariantMap相互转换,支持通过迭代器进行遍历,同时提供了插入、删除和查询等操作。QJsonObject是隐式共享的,不修改时可共享数据。以下是一些QJsonObject常用的接口及其功能说明:

构造函数

  • QJsonObject():创建一个空的QJsonObject对象。
  • QJsonObject(std::initializer_list<QPair<QString,QJsonValue>>args):通过参数初始化列表来初始化一个QJsonObject实例。
  • QJsonObject(constQJsonObject&other):创建一个QJsonObject的副本。
  • QJsonObject(QJsonObject&&other):使用移动语义创建一个QJsonObject的副本。

成员函数

  • bool contains(const QString&key) const:检查对象中是否包含给定的键。
  • int count() const:返回对象中包含的键值对数量,与size()函数功能相同。
  • bool empty() const:检查对象是否为空。
  • QJsonObject::iterator erase(QJsonObject::iterator it):从对象中删除迭代器所指向的键值对,并返回指向下一个键值对的迭代器。
  • QJsonObject::iterator find(const QString&key):返回一个迭代器,指向具有指定键的键值对。如果未找到,则返回end()。
  • QJsonObject::iterator insert(const QString&key,const QJsonValue&value):向对象中添加一个新的键值对。
  • QJsonObject::iterator begin():返回一个迭代器,指向对象中的第一个键值对。
  • QJsonObject::iterator end():返回一个迭代器,指向对象中的“尾后”位置。
  • QJsonObject::const_iterator begin() const:返回一个常量迭代器,指向对象中的第一个键值对。
  • QJsonObject::const_iterator end() const:返回一个常量迭代器,指向对象中的“尾后”位置。
  • QJsonObject::const_iterator find(const QString&key) const:返回一个常量迭代器,指向具有指定键的键值对。
  • QJsonObject fromVariantHash(const QVariantHash&hash):将QVariantHash转换为QJsonObject。
  • QJsonObject fromVariantMap(const QVariantMap&map):将QVariantMap转换为QJsonObject。
  • QVariantMap toVariantMap() const:将QJsonObject转换为QVariantMap。

示例


#include <QJsonObject>  
#include <QJsonDocument>  
#include <QDebug>  
  
int main() {  
    QJsonObject jsonObject;  
    jsonObject["name"] = "John";  
    jsonObject["age"] = 30;  
    jsonObject["city"] = "New York";  
  
    // 使用find函数查找键值对  
    QJsonObject::iterator it = jsonObject.find("age");  
    if (it != jsonObject.end()) {  
        qDebug() << "Age found:" << it.value().toString();  
    }  
  
    // 使用insert函数添加新的键值对  
    jsonObject.insert("occupation", "Developer");  
  
    // 将QJsonObject转换为QJsonDocument,然后转换为QByteArray  
    QJsonDocument jsonDoc(jsonObject);  
    QByteArray byteArray = jsonDoc.toJson(QJsonDocument::Compact);  
    qDebug() << "JSON data:" << byteArray;  
  
    return 0;  
}

在这个示例中,我们首先创建了一个QJsonObject对象并向其中添加了一些键值对。然后,我们使用find函数查找了一个键值对,并输出了它的值。接下来,我们使用insert函数添加了一个新的键值对。最后,我们将QJsonObject对象转换为了QJsonDocument对象,并进一步转换为了QByteArray对象,以便输出或传输。

总的来说,QJsonObject提供了丰富的接口来操作JSON对象,包括构造、查找、插入、删除和转换等功能。

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值