2

我有一个奇怪的问题:

    QString s1="abc";
    const char * ss1=s1.toUtf8().constData();
    QString s2=QString::fromUtf8(ss1);
    if(s1==s2)
      qDebug()<<"s1==s2";
    else
      qDebug()<<"s1!=s2";

上述代码的输出是“s1!=s2”。其实ss1和s2的内容是乱七八糟的。但是下面代码的输出是“s1==s2”。为什么?

    QString s1="abc";
    QString s2=QString::fromUtf8(s1.toUtf8().constData());
    if(s1==s2)
      qDebug()<<"s1==s2";
    else
      qDebug()<<"s1!=s2";
4

1 回答 1

4

因为您的代码中有未定义的行为:

const char * ss1 = s1.toUtf8().constData();

函数返回的 QByteArraytoUtf8()是一个临时对象,会被销毁。但是您保留了指向其数据的指针,然后您尝试使用它:

QString s2=QString::fromUtf8(ss1);

这会导致未定义的行为。

为此,您需要保持临时 QByteArray 对象处于活动状态。您可以为此使用 const 参考。它将延长临时对象的寿命:

QString s1 = "abc";
const auto& bytes = s1.toUtf8();
const char * ss1 = bytes.constData();

你的第二个例子很好,因为你没有使用任何指向被破坏对象内部内存的指针:

QString s2 = QString::fromUtf8(s1.toUtf8().constData());

由返回的临时 QByteArray 对象toUtf8()仅在调用返回后被fromUtf8()销毁。所以constData()指针的有效时间足以让函数读取数据。

于 2019-05-26T11:38:58.407 回答