通过 Qt 的来源进行了一些挖掘。
在qvariant.cpp
唯一的地方,unable to save type
错误调用在这里:
if (!QMetaType::save(s, d.type, constData())) {
Q_ASSERT_X(false, "QVariant::save", "Invalid type to save");
qWarning("QVariant::save: unable to save type %d.", d.type);
}
所以我去了QMetaType::save
:
bool QMetaType::save(QDataStream &stream, int type, const void *data)
{
...
case QMetaType::QPalette:
case QMetaType::QIcon:
case QMetaType::QImage:
...
if (!qMetaTypeGuiHelper)
return false;
qMetaTypeGuiHelper[type - FirstGuiType].saveOp(stream, data);
break;
...
return true;
}
qMetaTypeGuiHelper
声明如下:
Q_CORE_EXPORT const QMetaTypeGuiHelper *qMetaTypeGuiHelper = 0;
显然,在你的情况下qMetaTypeGuiHelper
等于零。所以我决定找到它的创建位置。并在QtGui
模块中找到:
static const QVariant::Handler *qt_guivariant_last_handler = 0;
int qRegisterGuiVariant()
{
qt_guivariant_last_handler = QVariant::handler;
QVariant::handler = &qt_gui_variant_handler;
qMetaTypeGuiHelper = qVariantGuiHelper;
return 1;
}
Q_CONSTRUCTOR_FUNCTION(qRegisterGuiVariant)
int qUnregisterGuiVariant()
{
QVariant::handler = qt_guivariant_last_handler;
qMetaTypeGuiHelper = 0;
return 1;
}
Q_DESTRUCTOR_FUNCTION(qUnregisterGuiVariant)
这意味着,为了保存你只QIcon
需要QVariant
调用qRegisterGuiVariant();
. 但是这个函数已经被QApplicationPrivate::initialize()
调用QApplicationPrivate::construct
了QApplication::QApplication(int &argc, char **argv)
所以我不得不问,在你的main
函数中,你创建QApplication
实例吗?
PS:那很有趣:)