如果在以utf8编码的文本文件中输入以下字符串(不带bom),并使用notepad.exe打开它,则会在屏幕上显示一些奇怪的字符。但是记事本实际上可以很好地解码此字符串,而无需最后一个“ a”。非常奇怪的行为。我正在使用Windows 10 1809。
[19, 16, 12, 14, 15, 15, 12, 17, 18, 15, 14, 15, 19, 13, 20, 18, 16, 19, 14, 16, 20, 16, 18, 12, 13, 14, 15, 20, 19, 17, 14, 17, 18, 16, 13, 12, 17, 14, 16, 13, 13, 12, 15, 20, 19, 15, 19, 13, 18, 19, 17, 14, 17, 18, 12, 15, 18, 12, 19, 15, 12, 19, 18, 12, 17, 20, 14, 16, 17, 18, 15, 12, 13, 19, 18, 17, 18, 14, 19, 18, 16, 15, 18, 17, 15, 15, 19, 16, 15, 14, 19, 13, 19, 15, 17, 16, 12, 12, 18, 12, 14, 12, 16, 19, 12, 19, 12, 17, 19, 20, 19, 17, 19, 20, 16, 19, 16, 19, 16, 12, 12, 18, 19, 17, 18, 16, 12, 17, 13, 18, 20, 19, 18, 20, 14, 16, 13, 12, 12, 14, 13, 19, 17, 20, 18, 15, 12, 15, 20, 14, 16, 15, 16, 19, 20, 20, 12, 17, 13, 20, 16, 20, 13a
我想知道这是Windows错误还是可以解决此问题。
答案 0 :(得分:0)
进行了更多研究;想通了。
似乎是经典案例“布什隐藏事实”的变体。 https://en.wikipedia.org/wiki/Bush_hid_the_facts
看起来记事本用于保存文件的默认字符编码与用于打开文件的默认字符编码不同。是的,这似乎是一个错误。
但是对于发生的情况有一个实际的解释:
记事本检查BOM表字节序列。如果找不到,则有2个选项:编码为UTF-16 Little Endian(无BOM)或纯ASCII。首先使用称为IsTextUnicode的函数检查UTF-16 LE。
IsTextUnicode对给定的文本是否为Unicode进行一系列的测试以猜测。这些测试之一是IS_TEXT_UNICODE_STATISTICS,它使用统计分析。如果测试为真,则给定的文本可能是Unicode,但不能绝对确定。
https://docs.microsoft.com/en-us/windows/desktop/api/winbase/nf-winbase-istextunicode
如果IsTextUnicode返回true,则记事本将使用UTF-16 LE对文件进行编码,从而产生您看到的奇怪输出。
我们可以用字符ㄠ来确认。其对应的ASCII字符为“ 1”(空格一);这些ASCII字符的对应十六进制值分别为0x20(空格)和0x31(1)。由于字节顺序为Little Endian,因此Unicode代码点的顺序为'1'或U + 3120,可以确认是否查找该代码点。
https://unicode-table.com/en/3120/
如果要解决此问题,则需要中断模式,该模式有助于IsTextUnicode确定给定文本是否为Unicode。您可以在文本之前插入换行符以破坏模式。
希望有帮助!