QString 类包含了大量关于文本字符串编码转换的函数,涉及之前提到的 UTF-8、UTF-16、UTF-32、本地语言编码 Local8Bit,还有标准 C++ 的普通字符串 StdString 和宽字符串 StdWString,对于其他编码转为 QString,采用的是 QString::from* 静态公有成员函数,这些静态函数返回一个转换好的 QString 对象以供使用。与之对应的是 QString 类对象的 to* 函数,QString 对象可以调用这些 to* 函数转出为其他编码格式的字符串。
下面将 QString 类这些成对的函数列一个表,方便查阅:
| 转入函数 | 转出函数 | 描述 |
|---|---|---|
| fromLocal8Bit | toLocal8Bit | 与操作系统及本地化语言相关,Linux 一般是 UTF-8 字符串,Windows 一般是 ANSI 多字节编码字符串。 |
| fromUtf8 | toUtf8 | 与 UTF-8 编码的字符串相互转换。 |
| fromUtf16 |
utf16 和 unicode |
与 UTF-16(UCS2)编码的字符串互相转换,utf16 函数与 unicode 函数功能一样, 注意没有 to 前缀,因为 QString 运行时的内码就是 UTF-16,字符的双字节采用主机字节序。 |
| fromUcs4 | toUcs4 | 与 UTF-32(UCS4)编码的字符串互相转换,一个字符用四个字节编码,占空间多,应用较少。 |
| fromStdString | toStdString | 与 std::string 对象互相转换,因为 C++11 规定标准字符串 std::string 使用 UTF-8 编码,这对函数功能与上面 **Utf8 转码函数相同。 |
| fromStdWString | toStdWString | 与 std::wstring 对象相互转换,在 Linux 系统里宽字符是四字节的 UTF-32,在 Windows 系统里宽字符是两字节的 UTF-16。因为不同平台有歧义,不建议使用。 |
|
fromCFString fromNSString |
toCFString toNSString |
仅存在于苹果 Mac OS X 和 iOS 系统。 |
下面展示一个 qtcodec 例子,里面主要使用 QString 对象的转出函数,然后使用 cout 或 qDebug 打印相应的输出。请「猛击这里」下载源代码。
下载后解压到比如 D:\QtDemo\qtcodec 文件夹,然后用 QtCreator 打开该项目,项目配置和上节示范的一样。 然后打开 qtcodec.cpp 文件,查看里面的内容:
//qtcodec.cpp
#include <QApplication>
#include <QTextBrowser>
#include <QDebug>
#include <iostream>
using namespace std;
void Testcout(const QString &str)
{
//Locale charset
cout<<str.toLocal8Bit().data()<<endl;
//UTF-8
cout<<str.toUtf8().data()<<endl;
cout<<str.toStdString()<<endl;
//UTF-16, Windows Unicode, UCS2
cout<<str.unicode()<<endl;
cout<<str.utf16()<<endl;
cout<<str.data()<<endl;
//UTF-32, UCS4
cout<<str.toUcs4().data()<<endl;
//wchar_t: Windows = UTF-16; Linux/Unix = UTF-32
wcout<<str.toStdWString();
cout<<endl<<endl;
}
void TestqDebug(const QString &str)
{
//Locale charset
qDebug()<<str.toLocal8Bit().data();
//UTF-8
qDebug()<<str.toUtf8().data();
qDebug()<<str.toStdString().data();
//UTF-16, Windows Unicode, UCS2
qDebug()<<str.unicode();
qDebug()<<str.utf16();
qDebug()<<str.data();
//UTF-32, UCS4
qDebug()<<str.toUcs4().data();
//wchar_t: Windows = UTF-16; Linux/Unix = UTF-32
qDebug()<<str.toStdWString().data();
//QString object
qDebug()<<str;
}
int main(int argc, char *argv[])
{
QApplication a(argc, argv);
QString strText = QObject::tr("1234打印汉字");
QTextBrowser tb;
tb.setText(strText);
tb.setGeometry(40, 40, 400, 300);
tb.show();
//Test cout
Testcout(strText);
//Test qDebug
//TestqDebug(strText);
return a.exec();
}
qtcodec.cpp 里面首先是头文件包含和名字空间使用,然后是三个函数:Testcout、TestqDebug 和 main 函数。Testcout 和 TestqDebug 函数里的内容参看上面表格,就不一一解释了。
需要注意一条,QString 类对象可以通过 data 函数返回它实际的数据存储块指针,如 str.data(),在后面运行测试时可以看到该指针数值。
注意两个测试函数不要同时启用,一次测试一个,另一个注释掉,这样查看它们运行结果更清楚,而不会混淆。
先测试 Testcout 函数运行效果: