QStringLiteral QLatin1String

QStringLiteral 是Qt5中新引入的一个用来从“字符串常量”创建QString对象的宏

ui->passwordEdit->setPlaceholderText(QStringLiteral("密码"));

QLatin1String类对US-ASCII/Latin-1编码的字符串进行了简单封装,可理解为关于const char*的一个浅封装。


if (str == "auto" || str == "extern"
        || str == "static" || str == "register") {
    ...
}

上面的代码执行会比下面的代码执行快很多

if (str == QString("auto") || str == QString("extern")
        || str == QString("static") || str == QString("register")) {
    ...
}

因为在第二部分的代码中会构造四个临时的QString对象,并复制字符串中的值。

在程序中定义了QT_NO_CAST_FROM_ASCII的应用程序是无法使用QString的const char*相关的API函数,因此Qt提供了QLatin1String类来更高效的利用const char*的类型,它就是一个关于const char*的一个浅封装。如果利用QLatin1String类来写上述的程序就是


if (str == QLatin1String("auto")
        || str == QLatin1String("extern")
        || str == QLatin1String("static")
        || str == QLatin1String("register") {
    ...
}

虽然在代码输入的时候有点长,但是它的执行效率和上面第一段的代码一样,同时也比使用QString::fromLatin1()转换来的快。

得益于QString(const QLatin1String&)这个构造函数,QLatin1String可以在任何需要QString对象的地方使用,比如:

QLabel *label = new QLabel(QLatin1String("MOD"), this);

QString str = "hello" 报错:

在程序中定义了QT_NO_CAST_FROM_ASCII的应用程序是无法使用QString的const char*相关的API函数,因此Qt提供了QLatin1String类来更高效的利用const char*的类型,它就是一个关于const char*的一个浅封装。

只要在 .pro文件里面


DEFINES += \
    QT_NO_CAST_FROM_ASCII

char*就不能转换成QString,这时候就可以用 QLatin1String来代替在所有需要QString的地方。

 

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值