我正在制作一个散列,通过向其提供包含其字符的QString,可以查找下面看到的描述。
我得到了相关数据的完整列表,看起来像这样:
QHash<QString, QString> lookupCharacterDescription;
...
lookupCharacterDescription.insert("003F","QUESTION MARK");
lookupCharacterDescription.insert("0040","COMMERCIAL AT");
lookupCharacterDescription.insert("0041","LATIN CAPITAL LETTER A");
lookupCharacterDescription.insert("0042","LATIN CAPITAL LETTER B");
...
lookupCharacterDescription.insert("1F648","SEE-NO-EVIL MONKEY");
lookupCharacterDescription.insert("1F649","HEAR-NO-EVIL MONKEY");
lookupCharacterDescription.insert("1F64A","SPEAK-NO-EVIL MONKEY");
lookupCharacterDescription.insert("1F64B","HAPPY PERSON RAISING ONE HAND");
...
lookupCharacterDescription.insert("FFFD","REPLACEMENT CHARACTER");
lookupCharacterDescription.insert("FFFE","<not a character>");
lookupCharacterDescription.insert("FFFF","<not a character>");
lookupCharacterDescription.insert("FFFFE","<not a character>");
lookupCharacterDescription.insert("FFFFF","<not a character>");
现在显然"1F64B"
需要在这里包裹起来。我曾尝试将0x1F64B
之类的东西用作QChar,但是老实说,我在这里摸索着摸索。我可以使它使用像拉丁字母这样的较低值,但是它不能使用5个字符的地址。
1F64B
进行分类? 答案 0 :(得分:5)
使用QString(0x1F64B)
时,它将呼叫QString::QString(QChar ch)
。由于QChar
是16位类型,它将截断值为0xF64B,并且由于该代码点当前未分配,您将获得无效字符。我很确定您会在该行收到超范围警告。如果放大或使用十六进制编辑器,则可以在字符F64B
中轻松查看值
。由于无法将0x1F64B放入单个16位QChar中并且必须由代理对来表示,因此您不能以这种方式初始化字符串。
OTOH QString("")
之所以有效,是因为它是从另一个字符串中构造字符串 。您必须使用这样的字符串来构造字符串,或者通过分配UTF-8 / 16代码单元来手动构造该字符串。
这被认为是UTF-32吗?
不。 UTF-32是Unicode编码,使用32位作为代码单元。您只有QString而没有裸字节数组,因此您无需关心其基础编码(实际上是UTF-16)
我可以将这个值“ 1F64B”包裹起来以产生QString(“”)吗?
您不应将数字值当作字符串处理。而是将其存储为数字类型
QHash<qint32, QString> lookupCharacterDescription;
lookupCharacterDescription.insert(0x1F64B, "HAPPY PERSON RAISING ONE HAND");
然后使用包含在代码点0x1F64B处的字符的字符串来使用
uint cp = 0x1F64B;
QString mystr = QString::fromUcs4(&cp, 1);
对于较低的值,包装纸也会起作用吗?
是的,从UCS4开始,又名UTF-32,可以存储任何可能的Unicode字符
或者,您可以从UTF-16或UTF-8构造字符。 U + 1F64B在UTF-16中编码为D83D DE4B
,在UTF-8中编码为F0 9F 99 8B
,因此您可以使用以下任何一种方式
QChar utf16[2] = { 0xD38D, 0xDE4B };
str1 = QString(utf16, 2);
char* utf8[4] = { 0xF0, 0x9F, 0x99, 0x8B };
str2 = QString::fromUtf8(utf8, 4);
如果您要在源代码中以原义形式包含字符串,则可以使用以下任一方法
str1 = QString::fromWCharArray(L"\xD83D\xDE4B");
str2 = QString::fromUtf8("\xF0\x9F\x99\x8B");
如果您具有C ++ 11支持,则只需分别对UTF-8,UTF-16和UTF-32使用前缀u8
,u
和U
,例如
u8""
u""
U""
u8"\U0001F64B"
u"\U0001F64B"
u"\uD83D\uDE4B"
U"\U0001F64B"
必读文章,以了解文本和编码:There Ain't No Such Thing as Plain Text