2 回答
TA貢獻(xiàn)1821條經(jīng)驗(yàn) 獲得超5個(gè)贊
char*轉(zhuǎn)換
Qt下面,字符串都用QString,確實(shí)給開(kāi)發(fā)者提供了方便,想想VC里面定義的各種變量類型,而且函數(shù)參數(shù)類型五花八門,經(jīng)常需要今年新那個(gè)類型轉(zhuǎn)換
Qt再使用第三方開(kāi)源庫(kù)時(shí),由于庫(kù)的類型基本上都是標(biāo)準(zhǔn)的類型,字符串遇的多的就是Char*類型
在Qt下怎樣將QString轉(zhuǎn)char*呢,需要用到QByteArray類,QByteArray類的說(shuō)明詳見(jiàn)Qt幫助文檔。
因?yàn)閏har*最后都有一個(gè)‘/0’作為結(jié)束符,而采用QString::toLatin1()時(shí)會(huì)在字符串后面加上‘/0’
方法如下:
Qstring str;
char* ch;
QByteArray ba = str.toLatin1();
ch=ba.data();
這樣就完成了QString向char*的轉(zhuǎn)化。經(jīng)測(cè)試程序運(yùn)行時(shí)不會(huì)出現(xiàn)bug
注意第三行,一定要加上,不可以str.toLatin1().data()這樣一部完成,可能會(huì)出錯(cuò)。
補(bǔ)充:以上方法當(dāng)QString里不含中文時(shí),沒(méi)有問(wèn)題,但是QString內(nèi)含有中文時(shí),轉(zhuǎn)換為char*就是亂碼,采用如下方法解決:
方法1:
添加GBK編碼支持:
#include <QTextCodec>
QTextCodec::setCodecForTr(QTextCodec::codecForName("GBK"));
QTextCodec::setCodecForLocale(QTextCodec::codecForName("GBK"));
然后改變上面的第三行為:QByteArray ba = str.toLoacl8Bit(); toLoacl8Bit支持中文
方法2:
先將QString轉(zhuǎn)為標(biāo)準(zhǔn)庫(kù)中的string類型,然后將string轉(zhuǎn)為char*,如下:
std::string str = filename.toStdString();
const char* ch = str.c_str();
TA貢獻(xiàn)1993條經(jīng)驗(yàn) 獲得超6個(gè)贊
#include <iostream>
#include <string>
using namespace std;
class my
{
public:
my(){}
my(const char * s){str=s;}
my(const my & s){str=s.str;}
my(const string & s){str=s;}
my operator =(const my & s){this->str=s.str;return * this;}
char operator [](int index) const{return str[index];}
bool operator ==(const my & s){return s.str==str;}
bool operator !=(const my & s){return s.str!=str;}
bool operator <(const my & s){return str<s.str;}
bool operator >(const my & s){return str>s.str;}
friend my operator +(const my & a,const my & b){return my(a.str+b.str);}
friend ostream & operator <<(ostream & os,my & s){return os<<s.str;}
private:
string str;
};
int main()
{
my a="abc",b;
b="def";
cout<<a+b<<endl;
cout<<a[2]<<endl;
my c;
c=a+b;
cout<<c<<endl;
return 0;
}
添加回答
舉報(bào)
