我试图通过以下方法将 QString 转换为 char* 类型,但它们似乎不起作用。
//QLineEdit *line=new QLineEdit();{just to describe what is line here}
QString temp=line->text();
char *str=(char *)malloc(10);
QByteArray ba=temp.toLatin1();
strcpy(str,ba.data());
您能否详细说明这种方法可能存在的缺陷,或者给出替代方法吗?
好吧,Qt FAQ 说:
int main(int argc, char **argv)
{
QApplication app(argc, argv);
QString str1 = "Test";
QByteArray ba = str1.toLocal8Bit();
const char *c_str2 = ba.data();
printf("str2: %s", c_str2);
return app.exec();
}
所以也许您还遇到其他问题。这到底怎么行不通?
也许
my_qstring.toStdString().c_str();
或更安全,正如 Federico 指出的:
std::string str = my_qstring.toStdString();
const char* p = str.c_str();
这远非最佳,但可以完成工作。
将 QString 转换为 char* 的最简单方法是 qPrintable(const QString& str), 这是一个扩展到
str.toLocal8Bit().constData()
的宏。
已编辑
这个方法也可以
QString str ("Something");
char* ch = str.toStdString().c_str();
如果您仅使用它输出到文件或在屏幕上显示,David 的答案效果很好,但如果函数或库需要 char* 进行解析,那么此方法效果最好:
// copy QString to char*
QString filename = "C:\dev\file.xml";
char* cstr;
string fname = filename.toStdString();
cstr = new char [fname.size()+1];
strcpy( cstr, fname.c_str() );
// function that requires a char* parameter
parseXML(cstr);
Qt提供最简单的API
const char *qPrintable(const QString &str)
const char *qUtf8Printable(const QString &str)
如果你想使用非常量数据指针
str.toLocal8Bit().data()
str.toUtf8().data()
您的字符串可能包含非 Latin1 字符,这会导致未定义的数据。这取决于你所说的“它似乎不起作用”是什么意思。
如果您的字符串包含非 ASCII 字符 - 最好这样做:
s.toUtf8().data()
(或s->toUtf8().data()
)
正确的解决方案是这样的
QString k;
k = "CRAZYYYQT";
char ab[16];
sprintf(ab,"%s",(const char *)((QByteArray)(k.toLatin1()).data()) );
sprintf(ab,"%s",(const char *)((QByteArray)(k.toStdString()).data()));
sprintf(ab,"%s",(const char *)k.toStdString().c_str() );
qDebug()<<"--->"<<ab<<"<---";
使用 std::vector 作为中间容器是一种可行的方法:
QString dataSrc("FooBar");
QString databa = dataSrc.toUtf8();
std::vector<char> data(databa.begin(), databa.end());
char* pDataChar = data.data();