繁体   English   中英

NodeJS UTF8编码一个缓冲区,然后解码该UTF8字符串产生一个具有不同内容的缓冲区

[英]NodeJS UTF8 Encoding A Buffer Then Decoding That UTF8 String Produces A Buffer With Different Content

我在nodejs控制台中输入了

new Buffer(new Buffer([0xde]).toString('utf8'), 'utf8')

它打印出来

<Buffer ef bf bd>

看完文档后 ,似乎会产生相同的缓冲区。 我正在从一个缓冲区中创建一个utf8编码的字符串,该缓冲区的内容由一个字节(0xde)组成,然后使用该utf8编码的字符串创建一个缓冲区。 我在这里想念什么吗?

对于可以是多字节的编码,您不能期望在所有情况下都能获得与开始时相同的字节。 对于UTF-8 ,某些字符需要多个字节才能正确表示。

在您的示例中, 0xde超过了0x7f ,这是可以由单个字节表示的字符的最大值。 因此,当您随后调用.toString('utf8') ,节点会看到它只有一个字节,而是返回UTF-8字符\� (十六进制的0xef, 0xbf, 0xbd ),用于表示未知/无法表示的字符。 然后,将这个“替换字符”值读回到新的Buffer中就没问题,因为它是有效的UTF-8字符。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM