std::string s2 = s2.toStdString(); const char* cc = s.c_str(); 上面的代码执行完后,cc打印出来是乱码 1 2 QByteArray ba = s1.toLatin1(); const char* cc = ba.data(); 换成这种方式来转换,cc打出来就正常了 上面就是QString转换为const char*后乱码的解决方案 分类: C++ , QT 好文...
转成char * : char*arr=str.toStdString.data(); 然而, 首先不谈toStdString没有加括号,正确的是toStdString()。这个代码本身就存在一些问题: const char* 和 char* 并不直接存储字符串中的字符,它们本身而是指针,指向的是一块内存空间,内存空间内才有字符串中的字符。在QString执行toStdString()函数后,返...
因为QString::toUtf8()返回的是一个QByteArray对象,如果这个QByteArray对象离开了它的作用域,那么由data()或constData()返回的指针可能就会指向一块无效的内存,从而导致乱码。 举个例子: const char* convertQStringToConstCharPtr(const QString& str) { QByteArray byteArray = str.toUtf8(); return byteArra...
编码一致性:在转换过程中,需要注意字符编码的一致性,以避免因编码不一致导致的乱码或错误。通常建议使用toUtf8()方法以确保编码的一致性。 异常处理:虽然QString到const char*的转换本身通常不会抛出异常,但在使用转换后的字符串时可能会遇到其他异常(如访问越界等)。因此,在使用转换后的字符串时,应确保操作的合法...
这里,我们将const char * 类型的字符串" (0000)"转换成为QString类型。 如果需要显式的转换,可以使用QString的强制转换操作,或者是使用函数fromAscii()等。 为了将QString类型转成const char *字符串,需要进行两步操作,一是使用toAscii()获得一个QByteArray类型对象, 然后调用它的data()或者constData()函数, ...
但是,如果转换后出现乱码,很可能是在字符串使用过程中出现了问题。 我之前遇到的问题是这样解决的:确保转换后的const char*在使用期间,它的原始QByteArray对象依然有效。因为QString::toUtf8()返回的是一个QByteArray对象,如果这个QByteArray对象离开了它的作用域,那么由data()或constData()返回的指针可能就会指向一...