QVariant識別類型的註冊mysql
首先必須先註冊myStructor--使用Q_DECLARE_METATYPE(myStructor)。
這是一個Macro--只能在全局中使用--不然出現錯誤。
而後就能夠按通常的方法來賦值了--取值代碼爲 v.value < myStructor >();
例子:
將一個指針賦予QVariant--可能有須要將一個指針賦予樹型列表控件(QTreeWidget)中一個條目--點擊此條目獲取指針對數據進行處理--而無須經過查找來取得數據--縮短處理時間。
用int指針做爲例子--QVariant不支持此類型必須先註冊。
ifndef __XXX__
define __XXX__
Q_DECLARE_METATYPE(int*);
...
endif
附帶記下如何在QTreeWidget控件中附加數據
增長Itemc++
QTreeWidgetItem* newItem = new QTreeWidgetItem;
...增長newItem到treeWidget中...
int* itemVal = new int (123);
QVariant Var;
Var.setValue (testVal); // 已註冊了int*--正確編譯
newItem->setData (0, 0, Var); //newItem的第一列附加了Var--即指向itemVal的指針
//第二個參數爲role角色的意思--我也不懂啥意思
點擊某個條目獲取對應的數據sql
on_treeWidget_click ()
{
...取得選擇的條目-curItem...
//Data()的參數和當時設置數據的參數同樣,value()是取得var的數據
int* ptr = curItem->Data (0, 0).value < int* >();
...對ptr進行處理...
}
QVariant類做爲一個最爲廣泛的Qt數據類型的聯合。數據庫
由於c++禁止沒有構造函數和析構函數的聯合體,許多繼承的Qt類不可以在聯合體當中使用。(聯合體當中的變量共用一個存儲區),沒有了聯合變量,咱們在物體屬性以及數據庫的工做等方面受到不少的困擾。函數
一個QVariant對象在一個時間內只保留一種類型的值。咱們可使用canConvert來查詢是否可以轉換當前的類型。轉換類型通常以toT()命名。ui
摘錄了一個example來講明QVariant的使用方法:spa
QDataStream out(...);
QVariant v(123); // The variant now contains an int
int x = v.toInt(); // x = 123 out << v; // Writes a type tag and an int to out v = QVariant("hello"); // The variant now contains a QByteArray v = QVariant(tr("hello")); // The variant now contains a QString int y = v.toInt(); // y = 0 since v cannot be converted to an int QString s = v.toString(); // s = tr("hello") (see QObject::tr()) out << v; // Writes a type tag and a QString to out ... QDataStream in(...); // (opening the previously written stream) in >> v; // Reads an Int variant int z = v.toInt(); // z = 123 qDebug("Type is %s", // prints "Type is int" v.typeName()); v = v.toInt() + 100; // The variant now hold the value 223 v = QVariant(QStringList());
你甚至能夠存儲QList<QVariant>和QMap<QString ,QVariant>.因此你能夠構造任意複雜的任意的數據類型。這個是很是強大並且又有
用的。QVariant也支持null值,你能夠定義一個沒有任何值的類型,然而,也要注意QVariant類型只能在他們有值的時候被強制轉換。
QVariant x, y(QString()), z(QString(""));
x.convert(QVariant::Int);
// x.isNull() == true
// y.isNull() == true, z.isNull() == false
由於QVariant是QtCore庫的一部分,它不可以提供定義在QtGui當中的類型的轉換,如QColor,QImage,he QPixmap等。換句話說,沒
有toColor()這樣的函數。取代的,你可使用QVariant::value()或者qVariantValue()這兩個模板函數。
QVariant variant; ... QColor color = variant.value<QColor>();
反向轉換(如把QColor轉成QVariant)是自動完成的。也包含了GUI相關的那些數據類型。
QColor color=palette().background().color();
QVariant variant=color;
#include "widget.h" #include <QDebug> #include <QVariant> #include <QColor> Widget::Widget(QWidget *parent) : QWidget(parent) { QVariant v(709); qDebug()<<v.toInt(); QVariant w("how are you!"); qDebug()<<w.toString(); QMap<QString, QVariant> map; map["int"] = 709; map["double"] = 709.709; map["string"] = "how are you!"; map["color"] = QColor(255,0,0); qDebug()<<map["int"]<<map["int"].toInt(); qDebug()<<map["double"]<<map["double"].toDouble(); qDebug()<<map["string"]<<map["string"].toString(); qDebug()<<map["color"]<<map["color"].value<QColor>(); QStringList sl; sl<<"a"<<"b"<<"c"<<"d"; QVariant slv(sl); if (slv.type() == QVariant::StringList){ QStringList list = slv.toStringList(); for (auto c: list) qDebug()<<c; } } Widget::~Widget() { }