- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我问Google上面的问题,然后被发送到Difference between UTF-8 and UTF-16?,不幸的是它没有回答问题。
根据我的理解,UTF-8应该是UTF-16的子集,这意味着:如果我的代码使用UTF-16,并且我交出了UTF-8编码的字符串,那么一切都应该很好。相反(期望UTF-8和获得UTF-16)可能会导致问题。
那是对的吗?
编辑:澄清为什么链接的SO问题不能回答我的问题:当尝试使用WebClient.DownloadString
处理JSON字符串时,我的问题出现了,因为WebClient使用了错误的编码。我从请求中收到的JSON编码为UTF-8,对我来说,问题是:如果我设置webClient.Encoding = New System.Text.UnicodeEncoding
(又名UTF-16),我将处于安全状态,即能够处理UTF-8和UTF-16请求结果,还是应该使用webClient.Encoding = New System.Text.UTF8Encoding
?
最佳答案
目前尚不清楚“兼容”的含义,因此让我们了解一些基础知识。
Unicode是基本概念,并且已正确实现,UTF-16和UTF-8是编码Unicode的两种不同方式。它们显然是不同的-否则,为什么会有两个不同的概念?
Unicode本身不指定序列化格式。 UTF-8和UTF-16是两种替代的序列化格式。
它们在表示相同的Unicode代码点的意义上是“兼容的”,而在表示形式上是完全不同的,因此它们是“不兼容的”。
UTF-16还有两个附加功能。实际上有两种不同的编码,UTF-16LE和UTF-16BE。这些在字节序方面有所不同。 (UTF-8是字节编码,因此不具有字节序。)旧版UTF-16过去被限制为65,536个可能的字符,该字符数少于Unicode当前包含的字符数。这是通过代理来处理的,但是真正的旧的和/或损坏的UTF-16实现(正确地标识为UCS-2,而不是“真正的” UTF-16)不支持它们。
有点儿困惑,让我们比较一下四个不同的代码点。我们选择U+0041,U+00E5,U+201C和U+1F4A9,因为它们很好地说明了差异。
U + 0041是7位字符,因此UTF-8仅用一个字节来表示它。 U + 00E5是8位字符,因此UTF-8需要对其进行编码。 U + 1F4A9在基本多语言平面之外,因此UTF-16用替代序列表示它。最后,U + 201C并非以上所述。
这是我们的候选字符在UTF-8,UTF-16LE和UTF-16BE中的表示形式。
Character | UTF-8 | UTF-16LE | UTF-16BE |
----------+---------------------+---------------------+---------------------+
U+0041 | 0x41 | 0x41 0x00 | 0x00 0x41 |
U+00E5 | 0xC3 0xA5 | 0xE5 0x00 | 0x00 0xE5 |
U+201C | 0xE2 0x80 0x9C | 0x1C 0x20 | 0x20 0x1C |
U+1F4A9 | 0xF0 0x9F 0x92 0xA9 | 0x3D 0xD8 0xA9 0xDC | 0xD8 0x3D 0xDC 0xA9 |
^@
),0x41是大写A,而0xE5未定义;例如Latin-1 in表示字符å(在Unicode中也方便地为U + 00E5),但是在KOI8-R中,它是西里尔字母Е(
U+0415),
etc.
关于encoding - UTF-16与UTF-8兼容吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32499846/
我使用术语“词法编码”是因为我没有更好的编码。 与字母相反,单词可以说是交流的基本单位。 Unicode 尝试为所有已知字母表的每个字母分配一个数值。对一种语言来说是字母,对另一种语言来说是字形。 U
我在UTF-8中有csv文件,我想将其保存在西里尔字母(Windows 1251)中...在中,我仅找到Atom -重新打开,并使用ctrl+shift+u编码 在 Sublime Text 3 中,
在lua 5.3引用手册中,我们可以看到: Lua is also encoding-agnostic; it makes no assumptions about the contents of a
看完后how gzip compression works它让我思考。如果源和代理服务器 (CDN) 都支持 gzip,则添加 Vary: Accept-Encoding头需要吗? 最佳答案 Vary
我正在向我的项目添加一项功能,我们将生成指向我们网站内部内容的链接,并且我们希望这些链接尽可能短,因此我们将制作自己的“URL 缩短器”。 我想知道生成的短网址的最佳编码/字母表是什么。这很大程度上是
我构建了一个用于压缩 HTTP 输出的模块。阅读spec ,我在以下几件事上没有发现明显的区别: 接受编码: 是否应将其视为与 Accept-Encoding: * 相同,还是视为不存在 header
在下面的代码中: package main import ( "bytes" "encoding/json" "fmt" ) type Student struct {
这个问题在这里已经有了答案: Why does encode delete the argument? (1 个回答) 6年前关闭。 Encode::encode 的文档说: encode $octe
在Android4.1中,实时编码应用中经常会请求关键帧。但是如何使用 MediaCodec 对象呢?当前的 Android4.2 SDK 似乎不支持它。 最佳答案 您可以 通过在排队输入缓冲区时指定
我有 CSV 格式的数据,这些数据在字符编码方面被严重打乱,可能在不同的软件应用程序(LibreOffice Calc、Microsoft、Excel、Google Refine、自定义 PHP/My
您可能知道,在 Perl 中,“utf8”意味着 Perl 对 UTF-8 的宽松理解,它允许使用技术上不是 UTF-8 中有效代码点的字符。相比之下,“UTF-8”(或“utf-8”)是 Perl
本文整理了Java中org.geotools.ysld.encode.YsldEncoder.encode()方法的一些代码示例,展示了YsldEncoder.encode()的具体用法。这些代码示例
现在还没有任何关于红色的书,因为它太新了。因此,我正在尝试遵循一本旧的 Rebol 书,并从中挽救我能得到的东西。 我发现一些命令,例如 read,由于文件编码的原因,我无法执行代码。 save %
错误:无法映射用于编码 UTF-8 的字符。由于版权特征,我收到此错误。我使用的是 Netbeans 7.2。 /** * � 2006 * * This class was generate
现在还没有任何关于红色的书,因为它太新了。因此,我正在尝试遵循一本旧的 Rebol 书,并从中挽救我能得到的东西。 我发现一些命令,例如 read,由于文件编码的原因,我无法执行代码。 save %
错误:无法映射用于编码 UTF-8 的字符。由于版权特征,我收到此错误。我使用的是 Netbeans 7.2。 /** * � 2006 * * This class was generate
我正在尝试使用客户端提供的值在 PHP 中测试 Soap Security header 。 他们提供的值(value)如... wTAmCL9tmg6KNpeAQOYubw== ...并说这是一个
这个问题已经有答案了: ClassNotFoundException/NoClassDefFoundError in my Java web application (3 个回答) 已关闭 8 年前。
世界!我正在使用 .Net Framework 4 System.Net.Sockets.TcpClient 编写简单的 HTML 服务器。 我在 StringBuilder html 中有 HTML
我正在尝试使用 Yii 来提供网络服务。自动生成的 wsdl 如下。我可以从命令行成功使用 Web 服务,但是通过 Web 浏览器,我得到了 SOAP-ERROR: Encoding: Violati
我是一名优秀的程序员,十分优秀!