主要是写给自己看的,每次都会出现中文字乱码的现象。
今天终于找到了解决方法,我在网上看到了这样的一段解释,源自于QT Center,是这样的:
rajeshs ask a question:
How can I convert a QString to char* and vice versa ?
Answer:
In order to convert a QString to a char*, then you first need to get a latin1 representation of the string by calling toLatin1() on it which will return a QByteArray. Then call data() on the QByteArray to get a pointer to the data stored in the byte array. See the documentation:
int main(int argc, char **argv)
{
QApplication app(argc, argv);
QString str1 = “Test”;
QByteArray ba = str1.toLatin1();
const char *c_str2 = ba.data();
printf(“str2: %s”, c_str2);
return app.exec();
}
Note that it is necessary to store the bytearray before you call data() on it, a call like the following
const char *c_str2 = str2.toLatin1().data();
will make the application crash as the QByteArray has not been stored and hence no longer exists.
To convert a char* to a QString you can use the QString constructor that takes a QLatin1String, e.g:
QString string = QString(QLatin1String(c_str2)) ;
上面代码中的加粗蓝色句子是关键,好多人都知道QString 转 const char*要经过两步:
(1)先通过toLatin1()或toAscii()方法转为QByteArray();
(2)再通过data()或constData()方法
就转换成了const char *。
但是,好多人都这样写的代码:
QString str;
const char *s = str.toLatin1().data();
或 const char *s = str.toAscii().data();
这样的话,str.toLatin1()的内容没有存储,就直接调用了data()方法。因此,结果就为空或者乱码。
正确的写法应该是这样的:
———————————————————————-
QString str;
QByteArray aByteArray = str.toLatin1();//先把转化为QByteArray的结果存储起来
const char *s = aByteArray.data();//再调用data()或constData()
————————————————————————————
或者:
QString str;
QByteArray aByteArray = str.toAscii();//先把转化为QByteArray的结果存储起来
const char *s = aByteArray.data();//再调用data()或constData()
——————————————————————————————————————–
Append:
今天找到了一个更好的解决方法:
QString str;
const char *temStr = str.toLocal8Bit();//(1)
qDebug()<<temStr;//(2)
这样,(2)处打印出来也是乱码,但是,可以这样直接把str.toLocal8Bit()放到你要用到const char *的地方,就可以了,我试了,能正常工作。
刚开始,看到qDebug出来的是乱码,以为不能用,后来发现不影响正常使用。
<div id="article_content" class="article_content clearfix csdn-tracking-statistics" data-pid="blog" data-mod="popu_307" data-dsm="post">
<div class="markdown_views">
<p>整合网络上的解决方法 <br>
解决方法一
1. string转const char*
string s = "abc";
const char* c_s = s.c_str();
- 1
- 2
-
const char*转string
直接赋值即可
const char* c_s = “abc”;
string s(c_s);
-
string转char*
string s = “abc”;
char* c;
const int len = s.length();
c = new char[len+1];
strcpy(c,s.c_str());
-
char*转string
char* c = “abc”;
string s(c);
-
const char*转char*
const char* cpc = “abc”;
char* pc = new char[100];//足够长
strcpy(pc,cpc);
-
char*转const char*
直接赋值即可
char* pc = “abc”;
const char* cpc = pc;
解决方法二
1. const char* 和string 转换
(1) const char*转换为 string,直接赋值即可。
EX: const char* tmp = “tsinghua”.
string s = tmp;
(2) string转换为const char*,利用c_str()
EX: string s = “tsinghua”;
const char*tmp = s.c_str();
2. char*和const char*之间的转换
(1) const char*转化为char*,利用const_cast
Qstring str = "helloworld";
char *s;
QByteArray ba = str.toLatin1();
s = ba.data();
- 1
- 2
- 3
- 4
这样就完成了 QString 向 char* 的转化。切记第三行 code 不可以省略。
- 将 char * 转化成 QString
Exp :
QString str;
char *s = "helloworld";
str = QString(QLatin1String(s));
- 1
- 2
- 3
std::string cstr;
QString qstring;
//从std::string 到QString
qstring = QString(QString::fromLocal8Bit(cstr.c_str()));
//从QString 到 std::string
cstr = string((const char *)qstring.toLocal8Bit());
//不需要从gbk转到utf8
QString value_content = QString::fromStdString(vec[i].content);
QString value_classname = QString::fromStdString(vec[i].classname);