在QT4中由于编码集过于陈旧导致遇到过一个“坑”:炉煻
这两个汉子是没办法正常显示的,而旧工程中大多数用的GB2312或GBK格式
在qt main函数中初始化代码大多如下:
#if (QT_VERSION <= QT_VERSION_CHECK(5, 0, 0))
// 这种编码集已经不推荐使用,过于陈旧的标准
//QTextCodec *pTextCodec = QTextCodec::codecForName("GB2312");
//QTextCodec *pTextCodec = QTextCodec::codecForName("GBK");
QTextCodec *pTextCodec = QTextCodec::codecForName("GB18030");
if(NULL != pTextCodec)
{
QTextCodec::setCodecForCStrings(pTextCodec);
QTextCodec::setCodecForLocale(pTextCodec);
QTextCodec::setCodecForTr(pTextCodec);
}
#endif
GB2312编码:1981年5月1日发布的简体中文汉字编码国家标准。GB2312对汉字采用双字节编码,收录7445个图形字符,其中包括6763个汉字。
BIG5编码:台湾地区繁体中文标准字符集,采用双字节编码,共收录13053个中文字,1984年实施。
GBK编码:1995年12月发布的汉字编码国家标准,是对GB2312编码的扩充,对汉字采用双字节编码。GBK字符集共收录21003个汉字,包含国家标准GB13000-1中的全部中日韩汉字,和BIG5编码中的所有汉字。
GB18030编码:2000年3月17日发布的汉字编码国家标准,是对GBK编码的扩充,覆盖中文、日文、朝鲜语和中国少数民族文字,其中收录27484个汉字。GB18030字符集采用单字节、双字节和四字节三种方式对字符编码。兼容GBK和GB2312字符集。
Unicode编码:国际标准字符集,它将世界各种语言的每个字符定义一个唯一的编码,以满足跨语言、跨平台的文本信息转换。Unicode采用四个字节为每个字符编码。
UTF-8和UTF-16编码:Unicode编码的转换格式,可变长编码,相对于Unicode更节省空间。UTF-16的字节序有大尾序(big-endian)和小尾序(little-endian)之别。