C++ 为什么使用QStringLiteral?
我最近开始使用QML,并尝试跟随。该视频讨论了如何创建一个C++模型,可以在QML应用程序中显示。 在模型的数据成员函数中,使用了一个开关,并在QVariant中返回将在QML中显示的字符串,但本教程还使用了一个额外的QStringLiteral,如下面的代码所示C++ 为什么使用QStringLiteral?,c++,qt,qml,C++,Qt,Qml,我最近开始使用QML,并尝试跟随。该视频讨论了如何创建一个C++模型,可以在QML应用程序中显示。 在模型的数据成员函数中,使用了一个开关,并在QVariant中返回将在QML中显示的字符串,但本教程还使用了一个额外的QStringLiteral,如下面的代码所示 QVariant ToDoModel::data(const QModelIndex &index, int role) const { if (!index.isValid()) return QVariant(
QVariant ToDoModel::data(const QModelIndex &index, int role) const
{
if (!index.isValid())
return QVariant();
// FIXME: Implement me!
switch (role)
{
case DoneRole:
return QVariant(false);
case DescriptionRole:
return QVariant(QStringLiteral("Test description"));
}
return QVariant();
}
我在没有QStringLiteral的情况下尝试了这段代码,它工作得很好,那么QStringLiteral的目的是什么呢
QStringLiteral的目的是什么
QString
是一个有趣的字符串类,能够处理静态和动态分配的字符串。动态分配在代码大小和性能方面都比较昂贵,但更灵活,通常更实用。无论如何,当您只需要一个字符串一次并且不会改变时,Qt有一个宏QStringLiteral
,它静态地分配字符串,并将其作为缓冲区分配给QString
类型化对象。除非为QString
对象分配了新字符串,否则将使用现有缓冲区
#define QT_UNICODE_LITERAL(str) QT_UNICODE_LITERAL_II(str)
#define QStringLiteral(str) \
([]() Q_DECL_NOEXCEPT -> QString { \
enum { Size = sizeof(QT_UNICODE_LITERAL(str))/2 - 1 }; \
static const QStaticStringData<Size> qstring_literal = { \
Q_STATIC_STRING_DATA_HEADER_INITIALIZER(Size), \
QT_UNICODE_LITERAL(str) }; \
QStringDataPtr holder = { qstring_literal.data_ptr() }; \
const QString qstring_literal_temp(holder); \
return qstring_literal_temp; \
}()) \
/**/
#定义QT_UNICODE_LITERAL(str)QT_UNICODE_LITERAL_II(str)
#定义QStringLiteral(str)\
([])Q_DECL_NOEXCEPT->QString{\
枚举{Size=sizeof(QT_UNICODE_LITERAL(str))/2-1}\
静态常量QStaticStringData qstring_literal={\
Q_静态_字符串_数据_标题_初始值设定项(大小)\
QT_UNICODE_LITERAL(str)}\
qstringdaptr holder={qstring_literal.data_ptr()}\
常量字符串字符串文字温度(保持器)\
返回qstring_literal_temp\
}()) \
/**/
这些类型问题的答案始终在文档中: