1,char * 转 QString
直接赋值,或者借助构造函数。
char * msg = "asdf123你好";
QString str1 = msg;
QString str2 = QString(msg);
2,QString 转 char *
方法1:(局部调用)
//正确的写法
QString qStr = QString("asdf123你好");
QByteArray byteArray = qStr.toUtf8();
char * ch_1 = byteArray.data();
//错误的写法
char * ch_2 = qStr.toUtf8().data(); //存在安全隐患
简单分析下 ch_2 错误的原因:
分析语句:char * ch_2 = qStr.toUtf8().data(); qStr.toUtf8() 返回一个QByteArray类型的临时结果(以下称 temp ),再由temp.data()将内存指针传出,赋值给ch_2。
这个过程如果写在一行表达式里,temp的生命周期在传回指针的那一刻就结束了,因此ch_2指向的内存数据是不可预料的。
(如果直接测试ch_2,会得到与ch_1同样的结果,但这只是一种表象,存在很大的安全隐患。原因:虽然中间变量 temp 的生命周期已经结束,但 temp 所占用过的内存依然存在,如果在调用ch_2之前该内存的数据没有被覆盖过,确实会得到与ch_1相同的结果。)
【方法2】更健壮。
方法2:(Qt 官方示例)
QString tmp = "test";
QByteArray text = tmp.toUtf8();
char *data = new char[text.size() + 1];
strcpy(data, text.data());
// ...业务代码...
delete [] data;