QVariant强制转换为基类型

QVariant cast to base type

本文关键字:基类 类型 转换 QVariant      更新时间:2023-10-16

我有一些像这样的类:

class QObjectDerived : public QObject
{
    Q_OBJECT
    // ...
};
Q_DECLARE_METATYPE(QObjectDerived*)

当这个类被存储到QVariant时,这样的行为发生

  QObjectDerived *object = new QObjectDerived(this);
  QVariant variant = QVariant::fromValue(object);
  qDebug() << variant;                          // prints QVariant(QObjectDerived*, )
  qDebug() << variant.value<QObject*>();        // prints QObject(0x0)
  qDebug() << variant.value<QObjectDerived*>(); // QObjectDerived(0x8c491c8)
  variant = QVariant::fromValue(static_cast<QObject*>(object));
  qDebug() << variant;                          // prints QVariant(QObject*, QObjectDerived(0x8c491c8) )
  qDebug() << variant.value<QObject*>();        // prints QObjectDerived(0x8c491c8)
  qDebug() << variant.value<QObjectDerived*>(); // QObject(0x0)

是否有任何方法将其存储在QVariant中,并能够将其作为QObject*和QObjectDerived*?

只写

QObject *value = variant.value<QObjectDerived*>();

可能可以为您的类型部分专门化qvariant_cast,但这不是文档支持的用例,我不愿意依赖它。

qvariant.h (Qt 4.8.6):

template<typename T>
inline T value() const
{ return qvariant_cast<T>(*this); }

template<typename T> inline T qvariant_cast(const QVariant &v)
{
    const int vid = qMetaTypeId<T>(static_cast<T *>(0));
    if (vid == v.userType())
        return *reinterpret_cast<const T *>(v.constData());
    if (vid < int(QMetaType::User)) {
        T t;
    if (qvariant_cast_helper(v, QVariant::Type(vid), &t))
        return t;
    }
    return T();
}

QObject *存储为内置的QMetaType::QObjectStar类型,QObjectDerived是元类型系统定义的带id的自定义类型。这意味着,您必须手动强制转换它。